324 lines
11 KiB
Plaintext
324 lines
11 KiB
Plaintext
<div class="row">
|
|
<div class="col-lg-2 col-md-2 col-sm-2">
|
|
<ul class="nav nav-tabs flex-column" role="tablist" >
|
|
<% @menu.each do |menu| %>
|
|
<li class="nav-item menu_category" data-ref="<%= api_restaurant_menu_category_path menu.id%>">
|
|
<p class="hidden menu-id"><%= menu.id %></p>
|
|
<a class="nav-link" data-toggle="tab" href="" role="tab"> <%= menu.name%></a>
|
|
|
|
</li>
|
|
<% end %>
|
|
</ul>
|
|
</div>
|
|
<div class="col-md-7 col-lg-7 col-sm-7">
|
|
<div class="card-columns menu_items_list" style="column-gap: 10px;">
|
|
<!-- append data -->
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-md-3 col-lg-3 col-sm-3">
|
|
<div class="card-header">
|
|
<div>
|
|
<strong id="order-title">ORDER DETAILS </strong> | Table <%=@table_id%>
|
|
</div>
|
|
</div>
|
|
<div class="card-block">
|
|
<div class="card-text" style="max-height:550px; overflow:auto"">
|
|
<table class="table table-striped summary-items">
|
|
<thead>
|
|
<tr>
|
|
<th>#</th>
|
|
<th class="item-name">Items</th>
|
|
<th class="item-qty">QTY</th>
|
|
<th class="item-attr">Price</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<div class="card-footer">
|
|
<table class="table" id="order-charges-table" border="0">
|
|
<tr>
|
|
<td class="charges-name"><strong>Sub Total:</strong></td>
|
|
<td class="item-attr"><strong id="sub_total">0.00</strong></td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Modal -->
|
|
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
|
|
<div class="modal-dialog" role="document">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
|
|
<button type="button" id="remove" class="btn btn-default" data-dismiss="modal" style="float:right;margin-right:30px;">Remove Item</button>
|
|
<h4 class="modal-title"></h4>
|
|
</div>
|
|
<div class="modal-body">
|
|
<div class="row">
|
|
<div class="col-lg-offset-6 col-md-offset-6 col-sm-offset-6 col-sm-6 col-md-6 col-lg-6">
|
|
<span id="item_err_msg"></span>
|
|
</div>
|
|
</div>
|
|
<div class="row">
|
|
|
|
<div class="col-md-6" style="width: 14.499999995%">
|
|
<label for="ex1">Qty</label>
|
|
<input type="hidden" id="modal_product_name">
|
|
<input type="hidden" id="modal_product_sku">
|
|
<input type="hidden" class="current_textbox">
|
|
<div id="modal_qty" class="form-control" ></div>
|
|
</div>
|
|
|
|
|
|
|
|
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-md-12">
|
|
<label for="ex1" style='width:50%;'>Price</label><span class="minus btn btn-default btn-xs" style='width:50%;'>-</span>
|
|
<div id="modal_price" class="form-control" ></div>
|
|
<input type="button" class="btn btn-primary btn-lg btn-block" id="clear" value="Clear">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
|
|
<button type="button" class="btn btn-primary">Save changes</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<script type="text/javascript">
|
|
|
|
$(function(){
|
|
|
|
//click menu sidebar menu category
|
|
$(".menu_category").on("click", function(){
|
|
var menu_id = $(this).find(".menu-id").text();
|
|
var url = $(this).attr('data-ref');
|
|
show_menu_item_list(url);
|
|
});
|
|
//End menu category Click
|
|
|
|
//show menu item list when click menu category
|
|
function show_menu_item_list(url_item){
|
|
var menu_list = $('.menu_items_list');
|
|
menu_list.empty();
|
|
|
|
//Start Ajax
|
|
$.ajax({
|
|
type: "GET",
|
|
url: url_item,
|
|
data: {},
|
|
dataType: "json",
|
|
success: function(data) {
|
|
var menu_items_list = $('.menu_items_list');
|
|
menu_items_list.empty();
|
|
menu_items = data.menu_items;
|
|
console.log(data);
|
|
for(var field in menu_items) {
|
|
if (menu_items[field].item_instances){
|
|
var price = parseFloat(menu_items[field].item_instances[1].price).toFixed(2);
|
|
var is_available = menu_items[field].item_instances[1].is_available
|
|
var is_on_promotion = menu_items[field].item_instances[1].is_on_promotion
|
|
var item_attributes = menu_items[field].item_instances[1].item_attributes
|
|
var item_instance_code = menu_items[field].item_instances[1].item_instance_item_code
|
|
var item_instance_name = menu_items[field].item_instances[1].item_instance_name
|
|
var promotion_price = menu_items[field].item_instances[1].promotion_price
|
|
}else{
|
|
var price = parseFloat(menu_items[field].price).toFixed(2);
|
|
var is_available = menu_items[field].is_available
|
|
var is_on_promotion = menu_items[field].is_on_promotion
|
|
var item_attributes = menu_items[field].item_attributes
|
|
var item_instance_code = menu_items[field].item_instance_item_code
|
|
var item_instance_name = menu_items[field].item_instance_name
|
|
var promotion_price = menu_items[field].promotion_price
|
|
}
|
|
|
|
row = '<div class="card">'
|
|
+'<div class="card-head" style="line-height:14px;">'
|
|
+'<small class="col-md-9">'+ menu_items[field].name +'</small>'
|
|
+'<div class="col-md-3 add_icon"'
|
|
+'data-id="'+ menu_items[field].name +'"'
|
|
+'data-item-code="'+ menu_items[field].item_code +'"'
|
|
+'data-name="'+ menu_items[field].name +'"'
|
|
+'data-price="'+ price +'"'
|
|
+'data-available="'+ is_available +'"'
|
|
+'data-promotion="'+ is_on_promotion +'"'
|
|
+'data-attributes="'+ item_attributes +'"'
|
|
+'data-instance-code="'+ item_instance_code +'"'
|
|
+'data-instance="'+ item_instance_name +'"'
|
|
+'data-promotion-price="'+ promotion_price +'"'
|
|
+'>'
|
|
+'<i class="fa fa-plus "'
|
|
+ 'style="margin-top:4px;">'
|
|
+'</i></div>'
|
|
+'</div>'
|
|
|
|
+'<div class="card-block">'
|
|
+'<%= image_tag "logo.png" ,width: '75', height: '75', :style => '' %>'
|
|
+'</div>'
|
|
|
|
+'<div class="card-footer">'
|
|
+'<small>'+ price +'</small>'
|
|
+'</div>';
|
|
$('.menu_items_list').append(row);
|
|
}
|
|
|
|
}
|
|
});
|
|
//end Ajax
|
|
}
|
|
//end show detail function
|
|
|
|
// click plus icon for add
|
|
$(document).on('click', '.add_icon', function(event){
|
|
var item_data = $(this);
|
|
show_item_detail(item_data);
|
|
calculate_sub_total();
|
|
}); //End Add Icon Click
|
|
|
|
function show_item_detail(data){
|
|
qty = 1;
|
|
append = 0;
|
|
price = data.attr('data-price');
|
|
instance_code = data.attr('data-instance');
|
|
|
|
if (instance_code == "undefined"){
|
|
instance = '';
|
|
}else{
|
|
instance = "("+data.attr('data-instance')+")";
|
|
}
|
|
|
|
var rowCount = $('.summary-items tbody tr').length+1;
|
|
var item_row = $('.summary-items tbody tr');
|
|
|
|
$(item_row).each(function(i){
|
|
if ($(item_row[i]).attr('data-code') == data.attr('data-item-code')) {
|
|
qty = parseInt($(item_row[i]).children('#item_qty').text()) +1;
|
|
$(item_row[i]).children('#item_qty').text(qty);
|
|
$(item_row[i]).children('#item_price').text(price*qty);
|
|
append = 1;
|
|
}else{
|
|
qty = 1;
|
|
}
|
|
});
|
|
|
|
if (append===0) {
|
|
row ="<tr data-price ='"+price+ "'data-toggle='modal' data-target='#myModal' 'data-instance ='"+instance+ "'data-code='"+data.attr('data-item-code')+"'>"
|
|
+'<td class="item-cell-no">'+rowCount+'</td>'
|
|
+'<td class="item-cell-name" >' + data.attr('data-name')+ ' ' + instance + '</td>'
|
|
+'<td class="item-cell-qty" id="item_qty">' + qty + '</td>'
|
|
+'<td class="item-cell-price" id="item_price">'
|
|
+ parseFloat(price).toFixed(2)
|
|
+'</td>'
|
|
+'</tr>';
|
|
$(".summary-items tbody").append(row);
|
|
}
|
|
|
|
}
|
|
|
|
function calculate_sub_total(){
|
|
var total_price = 0;
|
|
var taxable_amount = 0;
|
|
var item_row = $('.summary-items tbody tr');
|
|
|
|
$(item_row).each(function(i){
|
|
// var taxable = $(item_row[i]).attr('data-taxable');
|
|
var unit_price = parseFloat($(item_row[i]).attr('data-price'));
|
|
var qty = parseFloat($(item_row[i]).children('#item_qty').text());
|
|
// if(taxable == 'true'){
|
|
// taxable_amount += qty*unit_price;
|
|
// }
|
|
total_price += qty*unit_price;
|
|
});
|
|
var fixed_total_price = parseFloat(total_price).toFixed(2);
|
|
var fixed_taxable_amount = parseFloat(taxable_amount).toFixed(2);
|
|
$('#sub_total').empty();
|
|
$('#sub_total').append(fixed_total_price);
|
|
// $('#sub_total').attr('taxable_amount',fixed_taxable_amount);
|
|
// $('#show_sub').text(fixed_total_price);
|
|
}
|
|
|
|
});
|
|
</script>
|
|
|
|
|
|
<style type="text/css">
|
|
.card-head{
|
|
height: 40px;
|
|
background-color: #54A5AF;
|
|
padding:5px;
|
|
color :#fff;
|
|
}
|
|
.card-block {
|
|
padding: 0.3rem !important;
|
|
}
|
|
@media (min-width: 34em) {
|
|
.card-columns {
|
|
-webkit-column-count: 2;
|
|
-moz-column-count: 2;
|
|
column-count: 2;
|
|
}
|
|
}
|
|
|
|
@media (min-width: 48em) {
|
|
.card-columns {
|
|
-webkit-column-count: 3;
|
|
-moz-column-count: 3;
|
|
column-count: 3;
|
|
}
|
|
}
|
|
|
|
@media (min-width: 62em) {
|
|
.card-columns {
|
|
-webkit-column-count: 4;
|
|
-moz-column-count: 4;
|
|
column-count: 4;
|
|
}
|
|
}
|
|
|
|
@media (min-width: 75em) {
|
|
.card-columns {
|
|
-webkit-column-count: 4;
|
|
-moz-column-count: 4;
|
|
column-count: 4;
|
|
}
|
|
}
|
|
|
|
.nav-tabs .nav-item {
|
|
border-bottom: 1px solid #fff;
|
|
border-left: 1px solid #54A5AF;
|
|
border-right: 1px solid #54A5AF;
|
|
}
|
|
.nav > li > a{
|
|
color:#54A5AF;
|
|
}
|
|
.nav-tabs {
|
|
background-color: #eeeeee;
|
|
}
|
|
.nav-tabs .nav-link.active, .nav-tabs .nav-item.show .nav-link {
|
|
background-color: #fff;
|
|
border-left: 6px solid #111;
|
|
color:#54A5AF;
|
|
font-weight: bold;
|
|
border-color: #fff #fff #fff #54A5AF;
|
|
}
|
|
|
|
.modal-dialog {
|
|
left:auto;
|
|
right: auto;
|
|
width: 600px;
|
|
padding-top: 100px;
|
|
|
|
}
|
|
</style>
|
|
|
|
|