diff --git a/app/assets/javascripts/OQS.js b/app/assets/javascripts/OQS.js index 5ed26997..1588ac0f 100644 --- a/app/assets/javascripts/OQS.js +++ b/app/assets/javascripts/OQS.js @@ -29,11 +29,13 @@ $(document).ready(function(){ }); $(".oqs_click").on("click", function(){ - $("#completed").addClass('hide') - $(".oqs_append").removeClass('hide') - + $(".oqs_click").removeClass('oqs_active'); + $("#completed").addClass('hide'); + $(".oqs_append").removeClass('hide'); + $(this).addClass('oqs_active'); var oqs_id = $(this).find(".oqs-id").text(); var url = 'oqs/get_items/'+oqs_id; + show_details(url); }); //End Click diff --git a/app/assets/javascripts/channels/order.js b/app/assets/javascripts/channels/order.js new file mode 100644 index 00000000..eb73c5d1 --- /dev/null +++ b/app/assets/javascripts/channels/order.js @@ -0,0 +1,16 @@ +App.order = App.cable.subscriptions.create('OrderChannel', { +// App.messages = App.cable.subscriptions.create('MessagesChannel', { + + connected: function() {}, + + disconnected: function() {}, + + received: function(data) { + + $('.table_'+data.table.id).removeClass('green'); + $('.table_'+data.table.id).addClass('blue'); + + }, + +}); + diff --git a/app/assets/javascripts/channels/order_queue_station.js b/app/assets/javascripts/channels/order_queue_station.js index 79708e36..45a59b1d 100644 --- a/app/assets/javascripts/channels/order_queue_station.js +++ b/app/assets/javascripts/channels/order_queue_station.js @@ -6,24 +6,70 @@ App.order_queue_station = App.cable.subscriptions.create('OrderQueueStationChann disconnected: function() {}, received: function(data) { - console.log(data); - alert(data); - console.log("hiiiiiiiiiiii"); - $('#test').append(data); - }, + // console.log(data.order); + var oqs_id = $('.oqs_active').attr('data-id'); + items = data.order; + for(var field in items) { + var price = parseFloat(items[field].price).toFixed(2); + if (items[field]["options"] == "[]") { + var options = ""; + }else{ + var options = items.options; + } + //for count + test = document.getElementsByClassName("oqs_count"); + + for (var i = 0; i < test.length; i++) { + oqs_count_id = $(".oqs_count"+i).attr("data-id"); + oqs_count = $(".oqs_count"+i).text(); + if ( oqs_count_id == items[field]["order_queue_station_id"]) { + oqs_count_total = +oqs_count +1 ; + $(".oqs_count"+i).text(oqs_count_total) + } + } + //end count + + var date = new Date(items[field]["created_at"]); + var show_date = date.getDate() + "-" + date.getMonth() + "-" + date.getFullYear() + ' ' + date.getHours()+ ':' + date.getMinutes(); + + if (oqs_id == items[field]["order_queue_station_id"]) { + row ='
' + +'
' + +'

' + +''+items[field]["table_type"]+'- ' + +''+ items[field]["zone"] +'' + +''+ items[field]["order_id"] +'- ' + +'

' + + +'

' + +''+ items[field]["item_name"] +'- ' + +''+ items[field]["qty"] +'- ' + +'

' + + +'

'+ options +'

' + + +'

' + +'Order at' + +''+ show_date +' - ' + + +''+ items[field]["item_order_by"] +' ' + +' ' + +'

' + + +' ' + +' ' + +'
' + + +'' + +'
'; + $('.oqs_append').append(row); + } + } + // $("[data-behaviour='message']").html(data.order); + }, - order: function(message) { - return this.perform('order', { - message: message - }); - } }); -$(function(){ - $("#submit_order").on('click', function(event) { - var orderData=$("#new_order").serializeObject(); - App.order_station.order(orderData); - //orderData=''; - return event.preventDefault(); - }); -}); diff --git a/app/channels/order_channel.rb b/app/channels/order_channel.rb new file mode 100644 index 00000000..82b32b85 --- /dev/null +++ b/app/channels/order_channel.rb @@ -0,0 +1,11 @@ +class OrderChannel < ApplicationCable::Channel + def subscribed + stream_from "order_channel" + end + + def unsubscribed + stop_all_streams + # Any cleanup needed when channel is unsubscribed + end + +end diff --git a/app/jobs/order_broadcast_job.rb b/app/jobs/order_broadcast_job.rb index 28a152ce..ac483993 100644 --- a/app/jobs/order_broadcast_job.rb +++ b/app/jobs/order_broadcast_job.rb @@ -1,9 +1,8 @@ class OrderBroadcastJob < ApplicationJob queue_as :default - def perform(message) - order = Order.find(message) # message come as order_id - ApplicationCable.server.broadcast "order_queue_station_channel", order: order + def perform(table) + ActionCable.server.broadcast "order_channel",table: table end end diff --git a/app/jobs/order_queue_processor_job.rb b/app/jobs/order_queue_processor_job.rb index 4a6d2862..ede2ea54 100644 --- a/app/jobs/order_queue_processor_job.rb +++ b/app/jobs/order_queue_processor_job.rb @@ -5,17 +5,23 @@ class OrderQueueProcessorJob < ApplicationJob # Do something later #Order ID - order = Order.find(order_id) - ActionCable.server.broadcast "order_queue_station_channel",message: order + order = Order.find(order_id) + assign_order = AssignedOrderItem.assigned_order_item_by_job(order_id) #Loop through the order stations and process the items #Execute orders and send to order stations if order oqs = OrderQueueStation.new oqs.process_order(order, table_id) end - - - - + ActionCable.server.broadcast "order_queue_station_channel",order: assign_order end + + # private + + # def render_order(assign_order) + # ApplicationController.renderer.render(partial: 'oqs/oqs_test', + # locals: { order: assign_order}) + # end +# Read more at https://www.pluralsight.com/guides/ruby-ruby-on-rails/creating-a-chat-using-rails-action-cable#TehYiuqlHDOXaQQk.99 + end diff --git a/app/models/assigned_order_item.rb b/app/models/assigned_order_item.rb index 3ac84077..34c97c6f 100644 --- a/app/models/assigned_order_item.rb +++ b/app/models/assigned_order_item.rb @@ -17,6 +17,29 @@ class AssignedOrderItem < ApplicationRecord assigned_order_item.save end + def self.assigned_order_item_by_job(order_id) + order_item = AssignedOrderItem.select("assigned_order_items.assigned_order_item_id, + assigned_order_items.order_queue_station_id, + oqs.id as station_id, oqs.station_name, + oqs.is_active, oqpz.zone_id, + df.name as zone, df.type as table_type, + odt.order_id, odt.item_code, odt.item_name, + odt.price, odt.qty, odt.item_order_by, odt.options, + cus.name as customer_name, odt.created_at") + .joins(" left join order_queue_stations as oqs on oqs.id = assigned_order_items.order_queue_station_id + left join order_queue_process_by_zones as oqpz on oqpz.order_queue_station_id = oqs.id + left join orders as od ON od.order_id = assigned_order_items.order_id + left join order_items as odt ON odt.item_code = assigned_order_items.item_code AND odt.order_id = assigned_order_items.order_id + left join customers as cus ON cus.customer_id = od.customer_id + left join booking_orders as bo on bo.order_id = assigned_order_items.order_id + left join bookings as bk on bk.booking_id = bo.booking_id + left join dining_facilities as df on df.id = bk.dining_facility_id") + .where("assigned_order_items.order_id = '#{order_id}' AND assigned_order_items.delivery_status = false AND odt.price <> 0 AND assigned_order_items.created_at >= '#{Time.now.beginning_of_day.utc}' ") + .order("assigned_order_items.assigned_order_item_id desc") + .group("assigned_order_items.assigned_order_item_id") + return order_item + end + private def generate_custom_id self.assigned_order_item_id = SeedGenerator.generate_id(self.class.name, "AOI") diff --git a/app/models/order.rb b/app/models/order.rb index 0551a1c9..1887585c 100644 --- a/app/models/order.rb +++ b/app/models/order.rb @@ -49,7 +49,7 @@ class Order < ApplicationRecord process_order_queue #send order to broadcast job - #send_order_broadcast + send_order_broadcast(booking) return true, booking @@ -214,9 +214,10 @@ class Order < ApplicationRecord #send order items and send to order queue - def send_order_broadcast + def send_order_broadcast(booking) + table = DiningFacility.find(booking.dining_facility_id) #Send to background job for processing - OrderBroadcastJob.perform_later(self.id) + OrderBroadcastJob.perform_later(table) end #Origami: Cashier : to view order Table diff --git a/app/views/oqs/_oqs_test.html.erb b/app/views/oqs/_oqs_test.html.erb new file mode 100644 index 00000000..32b749ad --- /dev/null +++ b/app/views/oqs/_oqs_test.html.erb @@ -0,0 +1,51 @@ +<% order.each do |qid|%> + +
+
+

+ <%= qid.table_type %> - + <%= qid.zone %> + <%= qid.order_id %> +

+

+ + <%= qid.item_name %> + [x + + <%= qid.qty %> + ] +

+ +

+ <%= qid.options == "[]"? "" : qid.options %> +

+ +

+ Order at + + <%= qid.created_at.utc.getlocal.strftime("%d-%m-%Y %I:%M %p") %> + - + + <%= qid.item_order_by %> + + +

+ + + +
+
+<%end%> + \ No newline at end of file diff --git a/app/views/oqs/home/index.html.erb b/app/views/oqs/home/index.html.erb index ca52292e..001c901f 100644 --- a/app/views/oqs/home/index.html.erb +++ b/app/views/oqs/home/index.html.erb @@ -1,61 +1,60 @@ -
-
-
- <%= form_tag oqs_root_path, :method => :get do %> -
- -
-
- -
- - <% end %> -
-
-

-
-

-
+
+
+
+ <%= form_tag oqs_root_path, :method => :get do %> +
+ +
+ +
+ +
+ <% end %> +
+
@@ -110,7 +109,6 @@ -
diff --git a/app/views/origami/home/index.html.erb b/app/views/origami/home/index.html.erb index 4cdcf01d..9eb16a30 100644 --- a/app/views/origami/home/index.html.erb +++ b/app/views/origami/home/index.html.erb @@ -38,30 +38,30 @@
<% @tables.each do |table| %> - <% if table.status == 'occupied' %> - <% if table.get_booking.nil? %> -
-
- Zone <%= table.zone_id %>
- Table <%= table.name %> ( <%= table.seater %> Seat ) -
-
+ <% if table.status == 'occupied' %> + <% if table.get_booking.nil? %> +
+
+ Zone <%= table.zone_id %>
+ Table <%= table.name %> ( <%= table.seater %> Seat ) +
+
+ <% else %> +
+
+ Zone <%= table.zone_id %>
+ Table <%= table.name %> ( <%= table.seater %> Seat ) +
+
+ <% end %> <% else %> -
+
- Zone <%= table.zone_id %>
- Table <%= table.name %> ( <%= table.seater %> Seat ) + Zone <%= table.zone_id %>
+ Table <%= table.name %> ( <%= table.seater %> Seat )
<% end %> - <% else %> -
-
- Zone <%= table.zone_id %>
- Table <%= table.name %> ( <%= table.seater %> Seat ) -
-
- <% end %> <% end %>
@@ -70,19 +70,19 @@
<% @rooms.each do |room| %> - <% if room.status == 'occupied' %> -
-
- <%= room.name %> -
-
- <% else %> -
-
- <%= room.name %> -
-
- <% end %> + <% if room.status == 'occupied' %> +
+
+ <%= room.name %> +
+
+ <% else %> +
+
+ <%= room.name %> +
+
+ <% end %> <% end %>
diff --git a/app/views/origami/home/show.html.erb b/app/views/origami/home/show.html.erb index 2105918b..2d7cb895 100644 --- a/app/views/origami/home/show.html.erb +++ b/app/views/origami/home/show.html.erb @@ -59,7 +59,7 @@
<% end %> <% else %> -
+
<%= table.name %>
@@ -86,7 +86,7 @@
<% else %> -
+
<%= room.name %>