equal split and order split in order tab'
This commit is contained in:
@@ -386,9 +386,14 @@
|
||||
end
|
||||
%>
|
||||
</table>
|
||||
<button class='btn btn-primary btn-block waves-effect' id='add_invoice'> Add to existing invoice</button>
|
||||
<% if !@spit_bill.nil? && @spit_bill == '1' %>
|
||||
<button class='btn btn-primary btn-block waves-effect' id='split_bill'> Split Bill</button>
|
||||
|
||||
<% if !@split_bill.nil? %>
|
||||
<% if @split_bill == '1' %>
|
||||
<button class='btn btn-primary waves-effect' id='add_invoice'> Add to existing invoice</button>
|
||||
<button class='btn btn-primary waves-effect' id='split_bill'> Split Bill</button>
|
||||
<% else %>
|
||||
<button class='btn btn-primary btn-block waves-effect' id='add_invoice'> Add to existing invoice</button>
|
||||
<% end %>
|
||||
<% end %>
|
||||
<% end %>
|
||||
<% if @sale_array.size > 1 %>
|
||||
@@ -407,6 +412,11 @@
|
||||
<button class='btn btn-sm btn-primary invoicedetails' id="<%= sale.sale_id %>">Show
|
||||
Detail
|
||||
</button>
|
||||
<% if !@split_bill.nil? %>
|
||||
<% if @split_bill == '1' %>
|
||||
<button class='btn btn-sm btn-primary waves-effect' id='split_bill'> Split Bill</button>
|
||||
<% end %>
|
||||
<% end %>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
@@ -240,7 +240,8 @@
|
||||
|
||||
<!-- Column Three -->
|
||||
<div class="col-lg-1 col-md-1 col-sm-1">
|
||||
<button type="button" class="btn bg-default btn-block " id='back'><i class="material-icons">reply</i>Back</button>
|
||||
<button type="button" class="btn bg-default btn-block waves-effect" id='back'><i class="material-icons">reply</i>Back</button>
|
||||
<button type="button" class="btn bg-blue btn-block waves-effect" id='by_order'>By Order</button>
|
||||
<% if @sale_status != 'completed' %>
|
||||
<!-- <button type="button" class="btn bg-blue btn-block" id='move'>MOVE</button> -->
|
||||
<% end %>
|
||||
@@ -285,5 +286,59 @@
|
||||
})
|
||||
$('#move').on('click',function(){
|
||||
|
||||
})
|
||||
});
|
||||
|
||||
//order_split
|
||||
$('#by_order').on('click',function () {
|
||||
swal({
|
||||
title: "Alert",
|
||||
text: "Are you sure, you want to Split?",
|
||||
type: "warning",
|
||||
showCancelButton: true,
|
||||
confirmButtonColor: "#DD6B55",
|
||||
confirmButtonText: "Yes, split it!",
|
||||
closeOnConfirm: false
|
||||
}, function (isConfirm) {
|
||||
if(isConfirm){
|
||||
orderSplitBillProcess();
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
/* function for order items split bill process */
|
||||
function orderSplitBillProcess(){
|
||||
var booking = JSON.parse('<%= @booking.to_json.html_safe %>');
|
||||
var orders = JSON.parse('<%= @orders.to_json.html_safe %>');
|
||||
var order = JSON.parse('<%= @order.to_json.html_safe %>');
|
||||
var arr_order = [];
|
||||
arr_order.push({id : order.order_id});
|
||||
|
||||
var dining_id = booking[0].dining_facility_id || 0;
|
||||
var type = booking[0].type || '';
|
||||
var customer_id = order.customer_id || '';
|
||||
var booking_id = "";
|
||||
if(orders.length == 1){
|
||||
booking_id = booking[0].booking_id;
|
||||
}
|
||||
|
||||
var ajax_url = "/origami/split_bills";
|
||||
$.ajax({
|
||||
type: "POST",
|
||||
url: ajax_url,
|
||||
dataType: 'JSON',
|
||||
data: {'dining_id' : dining_id, 'type': type, 'customer_id' : customer_id, 'booking_id' : booking_id, 'order_ids' : [], 'order_items' : '', 'orders' : JSON.stringify(arr_order)},
|
||||
success: function (result) {
|
||||
if (!result.status) {
|
||||
swal("Information!", result.error_message);
|
||||
}
|
||||
else{
|
||||
if(type=='Table'){
|
||||
window.location.href = '/origami/table/' + dining_id;
|
||||
}else{
|
||||
window.location.href = '/origami/room/' + dining_id;
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
</script>
|
||||
|
||||
@@ -365,7 +365,7 @@
|
||||
%>
|
||||
</table>
|
||||
<button class='btn bg-primary' id='add_invoice'> Add to existing invoice </button>
|
||||
<% if !@spit_bill.nil? && @spit_bill == '1' %>
|
||||
<% if !@split_bill.nil? && @split_bill == '1' %>
|
||||
<button class='btn btn-primary' id='split_bill'> Split Bill</button>
|
||||
<% end %>
|
||||
<% end %>
|
||||
|
||||
@@ -20,18 +20,18 @@
|
||||
</div>
|
||||
<div id="split-order-slimscroll" data-height="70">
|
||||
<div class="card-text dining">
|
||||
<% if !@orders.nil? %>
|
||||
<% if !@orders.empty? %>
|
||||
<div class="row">
|
||||
<div class="col-lg-12 col-md-12 col-sm-12">
|
||||
<div class="row m-l-5">
|
||||
<div class="col-lg-3 col-md-3 col-sm-3">
|
||||
<ul class="nav nav-tabs tabs-left sideways">
|
||||
<li class="order-row active">
|
||||
<a href="#all_order" data-toggle="tab">All</a>
|
||||
<a href="#all_order" data-toggle="tab"><strong>All</strong></a>
|
||||
</li>
|
||||
<% @orders.each.with_index(0) do |order, order_index| %>
|
||||
<li class="order-row">
|
||||
<a href="#<%= order.order_id %>" data-toggle="tab"><%= order.order_id %></a>
|
||||
<a href="#<%= order.order_id %>" data-toggle="tab"><strong><%= order.order_id %></strong></a>
|
||||
</li>
|
||||
<% end %>
|
||||
</ul>
|
||||
@@ -188,13 +188,28 @@
|
||||
</div>
|
||||
<div id="split-receipt-slimscroll" data-height="150">
|
||||
<div class="card-text dining">
|
||||
<% if !@sale_data.nil? %>
|
||||
<% if !@sale_data.empty? %>
|
||||
<table class="table table-default">
|
||||
<thead>
|
||||
<th>#</th>
|
||||
<th>Receipt No.</th>
|
||||
<th>Total</th>
|
||||
<th>Action</th>
|
||||
</thead>
|
||||
<tbody>
|
||||
<% @sale_data.each do |sale_data| %>
|
||||
<% if sale_data.sale_status != 'completed' %>
|
||||
<tr class="receipt_row" id=<%= sale_data.sale_id %> >
|
||||
<td>Receipt No. - <span id="receipt_no"><%= sale_data.receipt_no %></span></td>
|
||||
<% @sale_data.each_with_index do |sale_data, sale_index| %>
|
||||
<% if sale_data.sale_status != 'completed' && sale_data.sale_status != 'void' %>
|
||||
<% checked = "" %>
|
||||
<% if sale_index == 0 %>
|
||||
<% checked = "checked" %>
|
||||
<% end %>
|
||||
<tr class="receipt-row" id=<%= sale_data.receipt_no %> data=<%= sale_data.grand_total %> >
|
||||
<td><input type="radio" name="rdn_receipt" id="rdn_receipt" value="<%= sale_data.sale_id %>" <%= checked %>></td>
|
||||
<td><span id="receipt_no"><%= sale_data.receipt_no %></span></td>
|
||||
<td><span id="grand_total"><%= sale_data.grand_total %></span></td>
|
||||
<td>
|
||||
<button type="button" class="btn btn-block waves-effect btn-primary btn_pay" id=<%= sale_data.sale_id %> >Pay</button>
|
||||
</td>
|
||||
</tr>
|
||||
<% end %>
|
||||
<% end %>
|
||||
@@ -213,16 +228,94 @@
|
||||
<!-- Action Panel -->
|
||||
<div>
|
||||
<button type="button" class="btn bg-default btn-block waves-effect" id="back" ><i class="material-icons">reply</i> Back </button>
|
||||
<button id="equal_split" class="btn btn-primary text-center action-btn waves-effect">= Split </button>
|
||||
<button id="order_split" class="btn btn-primary text-center action-btn waves-effect">By Order </button>
|
||||
<button id="order_item_split" class="btn btn-primary text-center action-btn waves-effect">By Order Item</button>
|
||||
<button id="equal_split" class="btn btn-block waves-effect bg-blue">= Split</button>
|
||||
<button id="order_split" class="btn btn-block waves-effect bg-blue">By Order</button>
|
||||
<button id="order_item_split" class="btn btn-block waves-effect bg-blue">By Order Item</button>
|
||||
</div>
|
||||
</div>
|
||||
<!-- Column Three -->
|
||||
</div>
|
||||
|
||||
<!-- modal for equal person -->
|
||||
<div class="modal fade" id="equal_split_modal" tabindex="-1" role="dialog" aria-labelledby="equal_split_modal_label" aria-hidden="true">
|
||||
<div class="modal-dialog" role="document">
|
||||
<div class="modal-content">
|
||||
<div class="modal-header">
|
||||
<h5 class="modal-title" id="equal_split_modal_label">Equal Split (per person)</h5>
|
||||
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
||||
<span aria-hidden="true">×</span>
|
||||
</button>
|
||||
</div>
|
||||
<div class="modal-body">
|
||||
<div class="form-horizontal">
|
||||
<div class="col-lg-12 col-md-12 col-sm-12">
|
||||
<div class="form-group">
|
||||
<input type="text" id="per_person" name="per_person" class="form-control" onkeypress="return isNumberKey(event);"/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<hr />
|
||||
<div class="p-l-50">
|
||||
<div class="row">
|
||||
<div class="col-lg-12 col-md-12 col-sm-12">
|
||||
<div class="row bottom">
|
||||
<div class="col-md-9">
|
||||
<div class="row">
|
||||
<div class="col-md-3 cashier_number" data-value="1" data-type="num" style="margin-left: 6px;">1</div>
|
||||
<div class="col-md-3 left cashier_number" data-value="2" data-type="num">2</div>
|
||||
<div class="col-md-3 left cashier_number" data-value="3" data-type="num">3</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row bottom clearfix">
|
||||
<div class="col-md-9">
|
||||
<div class="row">
|
||||
<div class="col-md-3 cashier_number" data-value="4" data-type="num" style="margin-left: 6px;">4</div>
|
||||
<div class="col-md-3 left cashier_number" data-value="5" data-type="num">5</div>
|
||||
<div class="col-md-3 left cashier_number" data-value="6" data-type="num">6</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row bottom">
|
||||
<div class="col-md-9">
|
||||
<div class="row">
|
||||
<div class="col-md-3 cashier_number" data-value="7" data-type="num" style="margin-left: 6px;">7</div>
|
||||
<div class="col-md-3 left cashier_number" data-value="8" data-type="num">8</div>
|
||||
<div class="col-md-3 left cashier_number" data-value="9" data-type="num">9</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row bottom">
|
||||
<div class="col-md-9">
|
||||
<div class="row">
|
||||
<div class="col-md-3 cashier_number" style="margin-left: 6px;"></div>
|
||||
<div class="col-md-3 left cashier_number red" data-type="del">DEL</div>
|
||||
<div class="col-md-3 left cashier_number green" data-type="clr">CLR</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<button type="button" class="btn bg-default" data-dismiss="modal">Close</button>
|
||||
<button type="button" class="btn bg-blue btn_per_person">Split Bill</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- modal for equal person -->
|
||||
</div>
|
||||
|
||||
<script type="text/javascript">
|
||||
var split_sale_id = "";
|
||||
var split_receipt_no = "";
|
||||
var split_total_amount = 0;
|
||||
$(document).ready(function(){
|
||||
|
||||
$('#back').on('click',function(){
|
||||
@@ -236,28 +329,28 @@
|
||||
var input_type = $(this).attr("data-type");
|
||||
switch (input_type) {
|
||||
case 'num':
|
||||
var input_value = $(this).attr("data-value");
|
||||
if (original_value == "0"){
|
||||
$('#per_person').val(input_value);
|
||||
}
|
||||
else{
|
||||
$('#per_person').val(original_value + '' + input_value);
|
||||
}
|
||||
var input_value = $(this).attr("data-value");
|
||||
if (original_value == "0"){
|
||||
$('#per_person').val(input_value);
|
||||
}
|
||||
else{
|
||||
$('#per_person').val(original_value + '' + input_value);
|
||||
}
|
||||
break;
|
||||
|
||||
case 'add':
|
||||
var input_value = $(this).attr("data-value");
|
||||
amount = parseInt(input_value);
|
||||
$('#per_person').val(amount);
|
||||
var input_value = $(this).attr("data-value");
|
||||
amount = parseInt(input_value);
|
||||
$('#per_person').val(amount);
|
||||
break;
|
||||
|
||||
case 'del' :
|
||||
var discount_text=$('#per_person').val();
|
||||
$('#per_person').val(discount_text.substr(0,discount_text.length-1));
|
||||
var discount_text=$('#per_person').val();
|
||||
$('#per_person').val(discount_text.substr(0,discount_text.length-1));
|
||||
break;
|
||||
|
||||
case 'clr':
|
||||
$('#per_person').val("0");
|
||||
$('#per_person').val("");
|
||||
break;
|
||||
}
|
||||
event.handled = true;
|
||||
@@ -307,6 +400,21 @@
|
||||
|
||||
// Selected Order
|
||||
$('.order-row').on('click',function(){
|
||||
var orders = JSON.parse('<%= @orders.to_json.html_safe %>');
|
||||
var check_order_id = $(this).find('a').attr('href').substr(1);
|
||||
|
||||
if(check_order_id == 'all_order'){
|
||||
if(orders.length > 0){
|
||||
$.each(orders, function(key,value){
|
||||
if($("a[href$='#"+value.order_id+"']").parent().hasClass('selected-split-item')){
|
||||
$("a[href$='#"+value.order_id+"']").parent().removeClass('selected-split-item');
|
||||
}
|
||||
});
|
||||
}
|
||||
}else{
|
||||
$("a[href$='#all_order']").parent().removeClass('selected-split-item');
|
||||
}
|
||||
|
||||
if($(this).hasClass('selected-split-item') == true){
|
||||
$(this).removeClass('selected-split-item');
|
||||
}
|
||||
@@ -319,7 +427,17 @@
|
||||
$('#order_split').on('click',function () {
|
||||
var cnt_orders = "<%= @orders.count %>";
|
||||
var orders = get_selected_orders();// Selected Order Items
|
||||
var cnt_odrs = parseInt(cnt_orders) - parseInt(orders.length);
|
||||
var cnt_odrs = 0;
|
||||
if(orders.length == 1){
|
||||
if(orders[0].id == 'all_order'){
|
||||
cnt_odrs = 0;
|
||||
}else{
|
||||
cnt_odrs = parseInt(cnt_orders) - parseInt(orders.length);
|
||||
}
|
||||
}else{
|
||||
cnt_odrs = parseInt(cnt_orders) - parseInt(orders.length);
|
||||
}
|
||||
|
||||
if (orders.length > 0){
|
||||
// if(cnt_odrs > 0){
|
||||
swal({
|
||||
@@ -345,12 +463,82 @@
|
||||
});
|
||||
|
||||
//selected receipt row click
|
||||
$('.receipt_row').on('click',function(){
|
||||
$('.btn_pay').on('click',function(){
|
||||
var dining_id = $("#table_id").text();
|
||||
var sale_id = $(this).attr('id').substr(0,16);
|
||||
window.location = '/origami/table/' + dining_id + "/table_invoice/" + sale_id;
|
||||
});
|
||||
|
||||
//equal split process
|
||||
$('#equal_split').on('click', function(){
|
||||
split_sale_id = $("input[type='radio'][name='rdn_receipt']:checked").val();
|
||||
split_receipt_no = $("input[type='radio'][name='rdn_receipt']:checked").parent().parent().attr('id');
|
||||
split_total_amount = $("input[type='radio'][name='rdn_receipt']:checked").parent().parent().attr('data');
|
||||
if(split_sale_id != undefined && split_sale_id != ""){
|
||||
$('#equal_split_modal').modal({backdrop: 'static', keyboard: true, show: true});
|
||||
}
|
||||
else{
|
||||
swal("Opps","Please select one receipt!","warning");
|
||||
}
|
||||
});
|
||||
|
||||
$('.btn_per_person').on('click', function(){
|
||||
$('#equal_split_modal').modal('hide');
|
||||
var person = parseInt($('#per_person').val());
|
||||
if(person > 1){
|
||||
var ajax_url = "/origami/split_bills/surveys";
|
||||
var dining_id = $("#table_id").text();
|
||||
var type = $("#table_type").text();
|
||||
|
||||
$.ajax({
|
||||
type: "POST",
|
||||
url: ajax_url,
|
||||
dataType: 'JSON',
|
||||
data: {'dining_id':dining_id, 'sale_id':split_sale_id, 'receipt_no':split_receipt_no, 'total_customer': person, 'total_amount':split_total_amount },
|
||||
success: function (result) {
|
||||
console.log(result);
|
||||
if(result.status){
|
||||
var ajax_url = "/origami/sale/" + split_sale_id + "/first_bill";
|
||||
$.ajax({
|
||||
type: "GET",
|
||||
url: ajax_url,
|
||||
success: function (result) {
|
||||
if((split_receipt_no!=undefined) && (split_receipt_no!=""))
|
||||
createReceiptNoInFirstBillData(split_receipt_no,"");
|
||||
|
||||
location.reload();
|
||||
// if(type=='Table'){
|
||||
// window.location.href = '/origami/table/' + dining_id;
|
||||
// }else{
|
||||
// window.location.href = '/origami/room/' + dining_id;
|
||||
// }
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
}else{
|
||||
var ajax_url = "/origami/sale/" + split_sale_id + "/first_bill";
|
||||
$.ajax({
|
||||
type: "GET",
|
||||
url: ajax_url,
|
||||
success: function (result) {
|
||||
if((split_receipt_no!=undefined) && (split_receipt_no!=""))
|
||||
createReceiptNoInFirstBillData(split_receipt_no,"");
|
||||
|
||||
location.reload();
|
||||
// if(type=='Table'){
|
||||
// window.location.href = '/origami/table/' + dining_id;
|
||||
// }else{
|
||||
// window.location.href = '/origami/room/' + dining_id;
|
||||
// }
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
//equal split process
|
||||
|
||||
//slimscroll for order, order items, reciept
|
||||
var height = ($(window).height() - ($('.legal').outerHeight() + $('.user-info').outerHeight() + $('.navbar').innerHeight()));
|
||||
|
||||
|
||||
@@ -142,7 +142,7 @@
|
||||
<div class="col-lg-1 col-md-1 col-sm-1">
|
||||
<button id="back" type="button" class="btn btn-block btn-lg bg-default"> <i class="material-icons">reply</i> <%= t("views.btn.back") %>
|
||||
<button type="button" id="pay" class="btn bg-blue btn-block">Pay</button>
|
||||
<button type="button" id="void" class="btn bg-danger btn-block"> Void </button>
|
||||
<button type="button" id="void" class="btn bg-danger btn-block" <%= (can? :overall_void, :void)? ' ': 'disabled=' %> active="true" > Void </button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@@ -173,22 +173,40 @@ $('#pay').on('click',function() {
|
||||
window.location.href = '/origami/sale/'+ sale_id + "/payment";
|
||||
});
|
||||
$('#back').on('click',function(){
|
||||
window.location.href = '/origami/table/<%= @table.id %>';
|
||||
var lookup_split_bill = '<%= @split_bill %>';
|
||||
if(lookup_split_bill == '1'){
|
||||
window.location.href = '/origami/table/<%= @table.id %>/split_bills';
|
||||
}else{
|
||||
window.location.href = '/origami/table/<%= @table.id %>';
|
||||
}
|
||||
|
||||
});
|
||||
$('#void').on('click',function () {
|
||||
var sure = confirm("Are you sure want to Void");
|
||||
if (sure == true) {
|
||||
var sale_id = $('#sale_id').val();
|
||||
var ajax_url = "/origami/sale/" + sale_id + '/void';
|
||||
$.ajax({
|
||||
type: 'POST',
|
||||
url: ajax_url,
|
||||
success: function () {
|
||||
window.location.href = '/origami/';
|
||||
}
|
||||
})
|
||||
} else {
|
||||
|
||||
$('#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').val();
|
||||
var ajax_url = "/origami/sale/" + sale_id + '/void';
|
||||
$.ajax({
|
||||
type: 'POST',
|
||||
url: ajax_url,
|
||||
success: function () {
|
||||
window.location.href = '/origami/';
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
}else{
|
||||
swal("Opps","You are not authorized for void","warning")
|
||||
}
|
||||
});
|
||||
</script>
|
||||
|
||||
Reference in New Issue
Block a user