diff --git a/app/controllers/api/authenticate_controller.rb b/app/controllers/api/authenticate_controller.rb index e94d6fd1..120335cc 100755 --- a/app/controllers/api/authenticate_controller.rb +++ b/app/controllers/api/authenticate_controller.rb @@ -62,6 +62,19 @@ class Api::AuthenticateController < Api::ApiController end end + def check_emp_access_code + pin_code = params[:code] + employee = Employee.find_by_emp_id(pin_code) + if employee && (employee.role == "manager" || employee.role == "supervisor") + result = {:status=> true, :message=>"Success" } + else + result = {:status=> false, :message=>"Invalid Access Code" } + end + render :json => result.to_json + end + +private + def authenticate_params params.permit(:emp_id, :password, :session_token) end diff --git a/app/controllers/api/bill_controller.rb b/app/controllers/api/bill_controller.rb index a5552fa2..5a6cf642 100755 --- a/app/controllers/api/bill_controller.rb +++ b/app/controllers/api/bill_controller.rb @@ -17,14 +17,18 @@ class Api::BillController < Api::ApiController @status = false @error_message = "Operation failed, Could not request bill!" else - # for Multiple Cashier by Zone - table = DiningFacility.find(booking.dining_facility_id) - order = booking.orders.first - cashier_zone = CashierTerminalByZone.find_by_zone_id(table.zone_id) - - shift = ShiftSale.where("shift_started_at is not null and shift_closed_at is null and cashier_terminal_id = #{cashier_zone.cashier_terminal_id}").first + unless shift = ShiftSale.current_open_shift(current_login_employee) + # for Multiple Cashier by Zone + if booking.dining_facility_id + table = DiningFacility.find(booking.dining_facility_id) + cashier_zone = CashierTerminalByZone.find_by_zone_id(table.zone_id) + shift = ShiftSale.where("shift_started_at is not null and shift_closed_at is null and cashier_terminal_id = #{cashier_zone.cashier_terminal_id}").first + else + shift = ShiftSale.current_shift + end + end #for multiple zone with terminal if !shift.nil? @@ -57,22 +61,22 @@ class Api::BillController < Api::ApiController # Bind shift sale id to sale # @sale_data.shift_sale_id = shift_by_terminal.id # @sale_data.save - if @sale_data + if @sale_data && booking.dining_facility_id.present? #check checkInOut pdf print checkout_time = Lookup.collection_of('checkout_time') - terminal = DiningFacility.find_by_id(booking.dining_facility_id) - cashier_terminal = CashierTerminal.find_by_id(terminal.zone_id) if (!checkout_time.empty?) && (ENV["SERVER_MODE"] != "cloud") #no print in cloud server + terminal = DiningFacility.find_by_id(booking.dining_facility_id) + cashier_terminal = CashierTerminal.find_by_id(terminal.zone_id) unique_code = "CheckInOutPdf" printer = PrintSetting.find_by_unique_code(unique_code) - # print when complete click - order_queue_printer = Printer::OrderQueuePrinter.new(printer) - if !printer.nil? - order_queue_printer.print_check_in_out(printer,cashier_terminal , booking, table) + # print when complete click + order_queue_printer = Printer::OrderQueuePrinter.new(printer) + + order_queue_printer.print_check_in_out(printer, cashier_terminal, booking, table) end end @@ -159,12 +163,11 @@ class Api::BillController < Api::ApiController if !shift.nil? cashier = Employee.find(shift.employee_id) if (@booking.booking_id) - booking_order = BookingOrder.find_by_booking_id(@booking.booking_id) - order = Order.find(booking_order.order_id) + order = @booking.orders.first if @sale_data = @booking.sale @status = true - elsif @sale_data = Sale.generate_invoice_from_booking(@booking, current_login_employee, cashier, order.source,params[:current_checkin_induties_count]) + elsif @sale_data = Sale.generate_invoice_from_booking(@booking, current_login_employee, cashier, order.source, params[:current_checkin_induties_count]) @status = true else @status = false diff --git a/app/controllers/api/bookings_controller.rb b/app/controllers/api/bookings_controller.rb index 797583f0..09b64137 100755 --- a/app/controllers/api/bookings_controller.rb +++ b/app/controllers/api/bookings_controller.rb @@ -1,14 +1,42 @@ class Api::BookingsController < Api::ApiController - # skip_before_action :authenticate + skip_before_action :authenticate #Show customer by ID - def index - @customer = Customer.find_by(params[:id]) + def index + @bookings = Booking.all + if params[:shift_id].present? + @bookings = @bookings.includes(:dining_facility, :sale, orders: :order_items) + .where() + end end def show - booking = Booking.find(params[:id]) - if booking.dining_facility_id.to_i == params[:table_id].to_i - @booking = booking + @booking = Booking.find(params[:id]) + end + + def pending + @bookings = Booking.where(checkout_at: nil) + end + + def billed + if shift = ShiftSale.current_shift + @bookings = Booking.includes(:sale) + .where(sales: {shift_sale_id: shift.id}) + .where.not(sales: {sale_status: ['completed', 'void']}) end end + + def completed + if shift = ShiftSale.current_shift + @bookings = Booking.includes(:sale) + .where(sales: {shift_sale_id: shift.id, sale_status: ['completed']}) + end + end + + def void + if shift = ShiftSale.current_shift + @bookings = Booking.includes(:sale) + .where(sales: {shift_sale_id: shift.id, sale_status: ['void']}) + end + end + end diff --git a/app/controllers/api/customers_controller.rb b/app/controllers/api/customers_controller.rb index 7a4663b4..daa72b70 100755 --- a/app/controllers/api/customers_controller.rb +++ b/app/controllers/api/customers_controller.rb @@ -21,6 +21,30 @@ class Api::CustomersController < Api::ApiController render json: status end + def get_customer_by_account + account_no = params[:account_no] + + unless @customer = Customer.find_by(paypar_account_no: account_no); + response = Customer.search_paypar_account_no(filter) + if response["status"] == true + @customer = Customer.create({ + name: response["customer_data"]["name"], + contact_no: response["customer_data"]["phone"], + email: response["customer_data"]["email"], + date_of_birth: response["customer_data"]["DOB"], + nrc_no: response["customer_data"]["NRC"], + address: response["customer_data"]["address"], + card_no: response["customer_data"]["customer_card_no"], + paypar_account_no: account_no, + membership_id: response["customer_data"]["id"], + membership_type: response["customer_data"]["member_group_id"], + customer_type: "Dinein", + tax_profiles: ["1", "2"], + }) + end + end + end + def get_customer_by_phone if @customer = Customer.find_by_contact_no(params[:contact_no]) status = true diff --git a/app/controllers/api/foodcourt/bills_controller.rb b/app/controllers/api/foodcourt/bills_controller.rb new file mode 100644 index 00000000..c932bca3 --- /dev/null +++ b/app/controllers/api/foodcourt/bills_controller.rb @@ -0,0 +1,25 @@ +class Api::Foodcourt::BillsController < Api::ApiController + + def create + Sale.transaction do + if shift = ShiftSale.current_open_shift(current_login_employee) + if booking = Booking.find(params[:booking_id]) + cashier = Employee.find(shift.employee_id) + order = booking.orders.first + + if @sale_data = booking.sale + @status = true + elsif @sale_data = Sale.generate_invoice_from_booking(booking, current_login_employee, cashier, order.source, params[:current_checkin_induties_count]) + @status = true + else + @status = false + end + end + else + @status = false + @error_message = "No Current Open Shift" + end + end + end + +end diff --git a/app/controllers/api/foodcourt/orders_controller.rb b/app/controllers/api/foodcourt/orders_controller.rb new file mode 100644 index 00000000..b5e1eccc --- /dev/null +++ b/app/controllers/api/foodcourt/orders_controller.rb @@ -0,0 +1,36 @@ +class Api::Foodcourt::OrdersController < Api::ApiController + + def create + Order.transaction do + if params[:order_items].present? + if shift = ShiftSale.current_open_shift(current_login_employee) + + @order = Order.new + @order.source = params[:source] || "foodcourt" + @order.order_type = params[:order_type] || "Takeaway" + @order.customer_id = params[:customer_id] || takeaway.customer_id # for no customer id from mobile + @order.items = params[:order_items] + @order.guest = params[:guest_info] + @order.table_id = params[:table_id] # this is dining facilities's id + @order.new_booking = true + @order.waiters = current_login_employee.name + @order.employee_name = current_login_employee.name + + @status, @booking = @order.generate + + unless @status && @booking + @status = false + @error_message = "Create order failed, some error occurred!" + end + else + @status = false + @error_message = "No Current Open Shift!" + end + else + @status = false + @error_message = "Parameters missing!" + end + end + end + +end diff --git a/app/controllers/api/foodcourt/payments_controller.rb b/app/controllers/api/foodcourt/payments_controller.rb new file mode 100644 index 00000000..9a9253a9 --- /dev/null +++ b/app/controllers/api/foodcourt/payments_controller.rb @@ -0,0 +1,88 @@ +class Api::Foodcourt::PaymentsController < Api::ApiController + + def create + SalePayment.transaction do + if params[:sale_id] && params[:account_no] + @sale = Sale.find_by_sale_id(params[:sale_id]) + if !@sale.nil? + if @sale.sale_status == "new" + if !params[:account_no].empty? + @status, @message = send_account_paymal(@sale.grand_total, params[:account_no], @sale.receipt_no) + if @status + sale_payment = SalePayment.new + status, @sale_payment, @membership_data = sale_payment.process_payment(@sale, current_login_employee, @sale.grand_total, "paymal",params[:account_no]) + + if status == true && @membership_data["status"] == true + # sale_payment = SalePayment.new + # status = sale_payment.process_payment(@sale, current_login_employee, 0, "cash") + #card_balance amount for Paymal payment + card_balance_amount, transaction_ref = SaleAudit.getCardBalanceAmount(params[:sale_id]) + + @status = true + @card_balance_amount = card_balance_amount + @transaction_ref = transaction_ref + @message = "Payment successful." + else + @status = false + if @membership_data + @card_balance_amount = @membership_data["card_balance_amount"] + @message = @membership_data["message"] + else + @message = "Payment failed!" + end + end + end + else + @status = false + @message = "Card No is required!" + end + else + @status = false + @message = "Already paid for '#{params[:sale_id]}'!" + end + else + @status = false + @message = "There is no sale for '#{params[:sale_id]}'!" + end + else + @status = false + @message = "Parameters missing! #{params[:sale_id]} #{params[:account_no]}" + end + end + end + + private + def send_account_paymal(amount, account_no, receipt_no) + sale = Sale.find_by_receipt_no(receipt_no) + @out = [] + action_by = current_login_employee.name + @status = true + @message = "" + membership_setting = MembershipSetting.find_by_membership_type("paypar_url") + if membership_setting.gateway_url + member_actions = MembershipAction.find_by_membership_type("get_account_balance") + if member_actions.gateway_url + @campaign_type_id = nil + url = membership_setting.gateway_url.to_s + member_actions.gateway_url.to_s + merchant_uid= member_actions.merchant_account_id + auth_token = member_actions.auth_token.to_s + membership_data = SalePayment.get_paypar_account_data(url,membership_setting.auth_token,merchant_uid,auth_token,account_no,amount,receipt_no) + if membership_data["status"]==true + remark = "Payment by account no Receipt No #{sale.receipt_no} | Sale ID #{sale.sale_id} | Transaction ref: #{membership_data[:transaction_ref]} | Reload amount #{membership_data[:reload_amount]} | Old Balance Amount #{membership_data[:old_balance_amount]} | DateTime : #{membership_data[:date]}" + sale_audit = SaleAudit.record_audit_for_edit(sale.sale_id,current_login_employee.name, current_login_employee.name,remark,"PAYBYACCOUNT" ) + else + remark = "Payment by account no Receipt No #{sale.receipt_no} | Sale ID #{sale.sale_id} | Remark : #{membership_data[:message]}" + sale_audit = SaleAudit.record_audit_for_edit(sale.sale_id,current_login_employee.name, current_login_employee.name,remark,"PAYBYACCOUNT" ) + end + @out = membership_data + @status = membership_data["status"] + @message = membership_data["message"] + end + else + @status = false + @message = "No gateway url!" + end + + return @status, @message + end +end diff --git a/app/controllers/api/foodcourt/void_controller.rb b/app/controllers/api/foodcourt/void_controller.rb new file mode 100644 index 00000000..904cdb9a --- /dev/null +++ b/app/controllers/api/foodcourt/void_controller.rb @@ -0,0 +1,60 @@ +class Api::Foodcourt::VoidController < Api::ApiController + + def create + sale_id = params[:sale_id] + order_source = params[:type] || "foodcourt" #tax profile source + access_code = params[:access_code] + remark = params[:remark] + + @sale = Sale.find_by_sale_id(sale_id) + + if @sale.discount_type == "member_discount" + @sale.update_attributes(total_discount: 0) + @sale.compute_by_sale_items(0, nil, order_source) + end + + # update count for shift @sale + if(@sale.sale_status == "completed") + if @sale.shift_sale_id != nil + shift = ShiftSale.find(@sale.shift_sale_id) + shift.calculate(sale_id, "void") + end + else + # void before @sale payment complete + if @sale.shift_sale_id != nil + shift = ShiftSale.find(@sale.shift_sale_id) + shift.total_void = shift.total_void + @sale.grand_total + shift.save + end + end + + @sale.rounding_adjustment = 0.0 + @sale.payment_status = 'void' + @sale.sale_status = 'void' + @sale.save + + if table = @sale.booking.dining_facility + unless table.current_bookings.exists? + table.update_attributes(status: 'available') + end + end + + # FOr Sale Audit + action_by = current_login_employee.name + if access_code != "null" && current_login_employee.role == "cashier" + action_by = Employee.find_by_emp_id(access_code).name + end + + # remark = "Void Sale ID #{sale_id} | Receipt No #{@sale.receipt_no} | Receipt No #{@sale.receipt_no} | Table ->#{table.name}" + sale_audit = SaleAudit.record_audit_for_edit(sale_id, current_login_employee.name, action_by, remark, "SALEVOID" ) + + if !@sale.sale_payments.nil? + membership_response = @sale.paymal_payment_void + Rails.logger.debug "---------Paymal Payment Void response in VoidController" + Rails.logger.debug membership_response.to_json + end + + @status = true + @message = "Void succeed" + end +end diff --git a/app/controllers/api/payments_controller.rb b/app/controllers/api/payments_controller.rb index 8a2f028b..e2c69bd7 100755 --- a/app/controllers/api/payments_controller.rb +++ b/app/controllers/api/payments_controller.rb @@ -19,56 +19,6 @@ class Api::PaymentsController < Api::ApiController def update end - #create paymal payment for cashier app - def create_paymal_payment - if params[:sale_id] && params[:account_no] - @sale = Sale.find_by_sale_id(params[:sale_id]) - if !@sale.nil? - if @sale.sale_status == "new" - if !params[:account_no].empty? - @status, @message = send_account_paymal(@sale.grand_total, params[:account_no], @sale.receipt_no) - if @status - sale_payment = SalePayment.new - status, @sale_payment, @membership_data = sale_payment.process_payment(@sale, current_login_employee, @sale.grand_total, "paymal",params[:account_no]) - - if status == true && @membership_data["status"] == true - sale_payment = SalePayment.new - status = sale_payment.process_payment(@sale, current_login_employee, 0, "cash") - #card_balance amount for Paymal payment - card_balance_amount, transaction_ref = SaleAudit.getCardBalanceAmount(params[:sale_id]) - - @status = true - @card_balance_amount = card_balance_amount - @transaction_ref = transaction_ref - @message = "Payment successful." - else - @status = false - if @membership_data - @card_balance_amount = @membership_data["card_balance_amount"] - @message = @membership_data["message"] - else - @message = "Payment failed!" - end - end - end - else - @status = false - @message = "Card No is required!" - end - else - @status = false - @message = "Already paid for '#{params[:sale_id]}'!" - end - else - @status = false - @message = "There is no sale for '#{params[:sale_id]}'!" - end - else - @status = false - @message = "Parameters missing! #{params[:sale_id]} #{params[:account_no]}" - end - end - #create paymal payment for online order app def paymal_payment if params[:account_no] && params[:key] && params[:token] && params[:sale_id] diff --git a/app/controllers/api/shifts_controller.rb b/app/controllers/api/shifts_controller.rb index 825a8fa1..c6e41df3 100644 --- a/app/controllers/api/shifts_controller.rb +++ b/app/controllers/api/shifts_controller.rb @@ -1,34 +1,34 @@ class Api::ShiftsController < Api::ApiController # skip_before_action :authenticate - - def create - opening_balance = 0 - cashier_terminal_param = params[:cashier_terminal] - # Multiple Cashier - cashier_terminal = CashierTerminal.find(cashier_terminal_param) - if cashier_terminal.is_currently_login - render json: JSON.generate({:status => false, :error_message => "Cashier Terminal already signin!"}) + def create + opening_balance = 0 + cashier_terminal_param = params[:cashier_terminal] + + # Multiple Cashier + cashier_terminal = CashierTerminal.find(cashier_terminal_param) + if cashier_terminal.is_currently_login + render json: JSON.generate({:status => false, :error_message => "Cashier Terminal already signin!"}) + else + # Update Cashier Terminal + cashier_terminal.is_currently_login = 1 + cashier_terminal.save + + @shift_sale = ShiftSale.new + if @shift_sale.create(opening_balance,cashier_terminal_param, current_login_employee) + @status = true + @message = "Cashier Terminal successfully signin." + # render json: JSON.generate({:status => true, :message => "Cashier Terminal successfully signin.", :shift => ActiveSupport::JSON.encode(@shift_sale)}) else - # Update Cashier Terminal - cashier_terminal.is_currently_login = 1 - cashier_terminal.save + @status = false + @error_message = "Some error occurred!" + # render json: JSON.generate({:status => false, :error_message => "Some error occurred!"}) + end + end + end - @shift_sale = ShiftSale.new - if @shift_sale.create(opening_balance,cashier_terminal_param, current_login_employee) - @status = true - @message = "Cashier Terminal successfully signin." - # render json: JSON.generate({:status => true, :message => "Cashier Terminal successfully signin.", :shift => ActiveSupport::JSON.encode(@shift_sale)}) - else - @status = false - @error_message = "Some error occurred!" - # render json: JSON.generate({:status => false, :error_message => "Some error occurred!"}) - end - end - end - - def update + def update closing_balance = 0 shift_id = params[:shift_id] @@ -36,26 +36,55 @@ class Api::ShiftsController < Api::ApiController if !@shift.nil? if @shift.shift_closed_at.nil? @shift.shift_closed_at = DateTime.now.utc - @shift.closing_balance = closing_balance.to_f + @shift.closing_balance = closing_balance.to_f @shift.save # Multiple Cashier - cashier_terminal = @shift.cashier_terminal + cashier_terminal = @shift.cashier_terminal cashier_terminal.is_currently_login = 0 cashier_terminal.save + @shop = current_shop + + @lookup = Lookup.shift_sale_items_lookup_value + + if @lookup.to_i == 1 + @sale_items = Sale.get_shift_sale_items(@shift.id) + other_charges = Sale.get_other_charges() + @total_other_charges_info = other_charges.where("sales.shift_sale_id IN (?) and sale_status='completed'",@shift) + end + + @sale_taxes = Sale.get_separate_tax(@shift,from=nil,to=nil,type='') + @total_waste = Sale.get_total_waste(shift_id).sum(:grand_total) + @total_spoile = Sale.get_total_spoile(shift_id).sum(:grand_total) + #other payment details for mpu or visa like card + @other_payment = ShiftSale.get_by_shift_other_payment(@shift) + + # Calculate price_by_accounts + @total_amount_by_account = ShiftSale.calculate_total_price_by_accounts(@shift,'amount') + @total_discount_by_account = ShiftSale.calculate_total_price_by_accounts(@shift,'discount') + @total_member_discount = ShiftSale.get_total_member_discount(@shift) + @total_dinein = ShiftSale.get_total_dinein(@shift).total_dinein_amount + @total_takeway = ShiftSale.get_total_takeway(@shift).total_takeway_amount + @total_other_charges = ShiftSale.get_total_other_charges(@shift).total_other_charges_amount + @total_credit_payments = ShiftSale.get_shift_sales_with_credit_payment(shift_id).total_credit_payments + @payment_methods = PaymentMethodSetting.where("is_active='1'").pluck("payment_method") + logout_status = Employee.logout(current_token) if logout_status - render json: JSON.generate({:status => true, :message => "Shift close successfully."}) - else - render json: JSON.generate({:status => false, :error_message => "Session Token Invalid or Missing"}) - end - else - render json: JSON.generate({:status => false, :error_message => "Shift already close!"}) + @status = true + @message = "Shift close successfully." + else + @status = false + @message = "Session Token Invalid or Missing" end + else + @status = false + @message = "Shift already close!" + end else - render json: JSON.generate({:status => false, :error_message => "Wrong shift!"}) + @status = false + @message = "Wrong shift!" end end end - diff --git a/app/controllers/foodcourt/addorders_controller.rb b/app/controllers/foodcourt/addorders_controller.rb index 51e4aa74..1349d310 100755 --- a/app/controllers/foodcourt/addorders_controller.rb +++ b/app/controllers/foodcourt/addorders_controller.rb @@ -20,13 +20,13 @@ class Foodcourt::AddordersController < BaseFoodcourtController @webview = true end display_type = Lookup.find_by_lookup_type("display_type") - if !display_type.nil? && display_type.value.to_i ==2 - @display_type = display_type.value - else - @display_type = nil - end - @menus = [] - @menu = [] + if !display_type.nil? && display_type.value.to_i ==2 + @display_type = display_type.value + else + @display_type = nil + end + @menus = [] + @menu = [] @table_id = params[:id] @table = DiningFacility.find(@table_id) diff --git a/app/controllers/foodcourt/orders_controller.rb b/app/controllers/foodcourt/orders_controller.rb index b1d41a06..6193572f 100755 --- a/app/controllers/foodcourt/orders_controller.rb +++ b/app/controllers/foodcourt/orders_controller.rb @@ -106,6 +106,10 @@ class Foodcourt::OrdersController < BaseFoodcourtController @menus = [] @menu = [] + @zone = Zone.all + @tables = Table.active.order('status desc') + @rooms = Room.active.order('status desc') + if params[:id].include? "BKI" @table_id = nil @table = nil @@ -272,7 +276,7 @@ class Foodcourt::OrdersController < BaseFoodcourtController end else respond_to do |format| - format.json { + format.json { render :json => { :status => false, :error_message => "No Current Open Shift for This Employee" } } end end diff --git a/app/controllers/foodcourt/shifts_controller.rb b/app/controllers/foodcourt/shifts_controller.rb index 792cf344..52235ef3 100755 --- a/app/controllers/foodcourt/shifts_controller.rb +++ b/app/controllers/foodcourt/shifts_controller.rb @@ -88,7 +88,6 @@ class Foodcourt::ShiftsController < BaseFoodcourtController end shop_details = current_shop #get tax - shift_obj = ShiftSale.where('id =?',@shift.id) sale_items = '' @lookup = Lookup.shift_sale_items_lookup_value if @lookup.to_i == 1 @@ -96,7 +95,7 @@ class Foodcourt::ShiftsController < BaseFoodcourtController other_charges = Sale.get_other_charges() @total_other_charges_info = other_charges.where("sales.shift_sale_id IN (?) and sale_status='completed'",@shift) end - @sale_taxes = Sale.get_separate_tax(shift_obj,from=nil,to=nil,type='') + @sale_taxes = Sale.get_separate_tax(@shift,from=nil,to=nil,type='') @total_waste = Sale.get_total_waste(shift_id).sum(:grand_total) @total_spoile = Sale.get_total_spoile(shift_id).sum(:grand_total) #other payment details for mpu or visa like card diff --git a/app/models/employee.rb b/app/models/employee.rb index 78b0ec66..93e38e0d 100755 --- a/app/models/employee.rb +++ b/app/models/employee.rb @@ -8,7 +8,9 @@ class Employee < ApplicationRecord validates_presence_of :name, :role validates_presence_of :password, :on => [:create] - validates :emp_id, uniqueness: { scope: :shop_code }, numericality: true, length: {in: 1..4}, allow_blank: true + validates :emp_id, numericality: true, length: {in: 1..4}, allow_blank: true + validates :emp_id, uniqueness: { scope: :shop_code }, if: -> { Employee.columns.map { |column| column.name }.include?('shop_code') } + validates :emp_id, uniqueness: true, if: -> { !Employee.columns.map { |column| column.name }.include?('shop_code') } validates :password, numericality: true, length: {in: 3..9}, allow_blank: true before_create :generate_app_id, :generate_app_token, diff --git a/app/models/sale.rb b/app/models/sale.rb index af43b8c2..7f933175 100644 --- a/app/models/sale.rb +++ b/app/models/sale.rb @@ -1434,9 +1434,9 @@ def self.get_separate_tax(shift_sale_range=nil,shift,from,to,payment_type) end if shift.present? - query = query.where("sales.shift_sale_id in (?) ", shift.to_a) + query = query.where(sales: { shift_sale_id: shift }) elsif shift_sale_range.present? - query = query.where("sales.shift_sale_id in (?) ", shift_sale_range.to_a) + query = query.where(sales: { shift_sale_id: shift_sale_range.to_a }) else query = query.where("sales.receipt_date between ? and ? ", from,to) end @@ -2034,7 +2034,7 @@ end .where("sales.shift_sale_id=?", sh_id) .group("acc.title,i.account_id,i.menu_category_code,i.item_instance_code,i.product_name,i.unit_price") .order("acc.title desc, i.account_id desc, i.menu_category_code desc, i.unit_price asc") -end + end def self.pending_sale(type) query = Sale.all @@ -2043,6 +2043,7 @@ end query = query.where("sales.sale_status = 'new' AND orders.status = 'billed' AND orders.source =? ","#{type}") .group("sales.sale_id") end + def self.pending_order(type) query = Booking.all query = query.joins("join booking_orders as booking_orders on booking_orders.booking_id = bookings.booking_id") @@ -2050,6 +2051,7 @@ end query = query.where("bookings.booking_status = 'assign' AND orders.status = 'new' AND orders.source =? ","#{type}") .group("bookings.booking_id") end + def self.completed_sale(type) if type == "cashier" type = "and orders.source = 'emenu' or orders.source = 'cashier'" diff --git a/app/models/sale_tax.rb b/app/models/sale_tax.rb index dfe83b0a..c5ecb728 100755 --- a/app/models/sale_tax.rb +++ b/app/models/sale_tax.rb @@ -36,7 +36,7 @@ class SaleTax < ApplicationRecord end def display_name - "#{self.tax_name} (#{'Incl. ' if self.tax_type == 'inclusive'}#{self.tax_rate}%" + "#{self.tax_name} (#{'Incl.' if self.inclusive} #{self.tax_rate}%" end private diff --git a/app/models/shift_sale.rb b/app/models/shift_sale.rb index a360b45b..30add9ec 100755 --- a/app/models/shift_sale.rb +++ b/app/models/shift_sale.rb @@ -154,9 +154,9 @@ class ShiftSale < ApplicationRecord shift_other_payments = Sale.select("sales.sale_id, sale_payments.payment_method as name") if payment_methods.present? - shift_other_payments = shift_other_payments.select("#{payment_methods.map { |method| "SUM(case when (sale_payments.payment_method='#{method}') then sale_payments.payment_amount else 0 end) as `#{method == 'paypar' ? 'redeem' : method}`"}.join(', ')}") + shift_other_payments = shift_other_payments.select("#{payment_methods.map { |method| "IFNULL(SUM(case when (sale_payments.payment_method='#{method}') then sale_payments.payment_amount else 0 end), 0) as `#{method == 'paypar' ? 'redeem' : method}`"}.join(', ')}") end - shift_other_payments.select("SUM(case when (sale_payments.payment_method='foc') then (sale_payments.payment_amount) else 0 end) as foc_amount") + shift_other_payments.select("IFNULL(SUM(case when (sale_payments.payment_method='foc') then (sale_payments.payment_amount) else 0 end), 0) as foc_amount") .joins("join sale_payments on sale_payments.sale_id = sales.sale_id") .where("sales.shift_sale_id =? and sale_status = 'completed' and sale_payments.payment_amount != 0 ", shift.id) end @@ -204,7 +204,7 @@ class ShiftSale < ApplicationRecord # end def self.get_total_other_charges(shift) - query = SaleItem.select("sum(sale_items.qty * sale_items.unit_price) as total_other_charges_amount") + query = SaleItem.select("IFNULL(sum(sale_items.qty * sale_items.unit_price), 0) as total_other_charges_amount") .joins("JOIN sales as s ON s.sale_id = sale_items.sale_id") .where('shift_sale_id =? and s.sale_status = "completed" and sale_items.product_code = "Other Charges" and sale_items.item_instance_code is null',shift.id) .first() diff --git a/app/views/api/bill/create.json.jbuilder b/app/views/api/bill/create.json.jbuilder index 332a9cec..70ced95a 100755 --- a/app/views/api/bill/create.json.jbuilder +++ b/app/views/api/bill/create.json.jbuilder @@ -1,6 +1,25 @@ if @status == true #show invoice number and stuff json.status @status + json.sale_id @sale_data.sale_id + sale = Sale.find(@sale_data.sale_id) + + json.sale_items sale.sale_items do |sale_item| + json.sale_item_id sale_item.sale_item_id + json.sale_id sale_item.sale_id + json.product_code sale_item.product_code + json.item_instance_code sale_item.item_instance_code + json.product_name sale_item.product_name + json.product_alt_name sale_item.product_alt_name + json.account_id sale_item.account_id + json.status sale_item.status + json.remark sale_item.remark + json.qty sale_item.qty + json.unit_price sale_item.unit_price + json.taxable_price sale_item.taxable_price + json.price sale_item.price + json.is_taxable sale_item.is_taxable + end else json.status @status json.error_message @error_message diff --git a/app/views/api/bookings/_booking_summary.json.jbuilder b/app/views/api/bookings/_booking_summary.json.jbuilder new file mode 100644 index 00000000..07d7761f --- /dev/null +++ b/app/views/api/bookings/_booking_summary.json.jbuilder @@ -0,0 +1,8 @@ +json.booking_id booking.booking_id + +json.sale_id booking.sale.try(:sale_id) +json.sale_status booking.sale.try(:sale_status) +json.receipt_no booking.sale.try(:receipt_no) + +json.checkin_at booking.try(:checkin_at).try(:utc) +json.checkout_at booking.try(:checkout_at).try(:utc) diff --git a/app/views/api/bookings/billed.json.jbuilder b/app/views/api/bookings/billed.json.jbuilder new file mode 100644 index 00000000..6a10cb6c --- /dev/null +++ b/app/views/api/bookings/billed.json.jbuilder @@ -0,0 +1 @@ +json.array! @bookings, partial: 'api/bookings/booking_summary', as: :booking diff --git a/app/views/api/bookings/completed.json.jbuilder b/app/views/api/bookings/completed.json.jbuilder new file mode 100644 index 00000000..6a10cb6c --- /dev/null +++ b/app/views/api/bookings/completed.json.jbuilder @@ -0,0 +1 @@ +json.array! @bookings, partial: 'api/bookings/booking_summary', as: :booking diff --git a/app/views/api/bookings/pending.json.jbuilder b/app/views/api/bookings/pending.json.jbuilder new file mode 100644 index 00000000..6a10cb6c --- /dev/null +++ b/app/views/api/bookings/pending.json.jbuilder @@ -0,0 +1 @@ +json.array! @bookings, partial: 'api/bookings/booking_summary', as: :booking diff --git a/app/views/api/bookings/show.json.jbuilder b/app/views/api/bookings/show.json.jbuilder index 5cef3269..b55a7286 100755 --- a/app/views/api/bookings/show.json.jbuilder +++ b/app/views/api/bookings/show.json.jbuilder @@ -1,50 +1,15 @@ if (@booking) - json.success true - json.id @booking.booking_id - json.status @booking.booking_status - if Sale.exists?(@booking.sale_id) - json.sale_status Sale.find(@booking.sale_id).sale_status - else - json.sale_status "" - end - json.checkin_at @booking.checkin_at.strftime("%d-%m-%Y") - json.checkin_by @booking.checkin_by - json.table_name @booking.dining_facility.name + json.booking_id @booking.booking_id - if @booking.type == "TableBooking" - json.table_id @booking.dining_facility_id - else - json.room_id @booking.dining_facility_id - end - @total_amount = 0.00 - @total_tax = 0.00 + json.booking_status @booking.booking_status - if @booking.booking_orders - order_items = [] - @booking.booking_orders.each do |bo| - order = Order.find(bo.order_id) - #if (order.status == "new") - order_items = order_items + order.order_items - #end - end - - json.order_items order_items do |item| - json.item_instance_code item.item_code - json.item_name item.item_name - json.price item.price - json.qty item.qty - json.options item.options - json.remark item.remark - json.item_status item.order_item_status - @total_amount = @total_amount + (item.price * item.qty) - else - json.success false - end + json.dining_facility do + json.partial! 'api/dining_facilities/dining_facility', dining_facility: @booking.dining_facility end - json.sub_total @total_amount - json.commerical_tax @total_amount * 0.05 - json.total @total_amount + (@total_amount * 0.05) -else - json.success false + json.sale do + json.partial! 'api/sales/sale', sale: @booking.sale + end + + json.orders @booking.orders, partial: 'api/orders/order', as: :order end diff --git a/app/views/api/bookings/void.json.jbuilder b/app/views/api/bookings/void.json.jbuilder new file mode 100644 index 00000000..6a10cb6c --- /dev/null +++ b/app/views/api/bookings/void.json.jbuilder @@ -0,0 +1 @@ +json.array! @bookings, partial: 'api/bookings/booking_summary', as: :booking diff --git a/app/views/api/customers/get_customer_by_account.json.jbuilder b/app/views/api/customers/get_customer_by_account.json.jbuilder new file mode 100644 index 00000000..bb993467 --- /dev/null +++ b/app/views/api/customers/get_customer_by_account.json.jbuilder @@ -0,0 +1,7 @@ +if @customer.present? + json.status true +else + json.status false +end + +json.data @customer diff --git a/app/views/api/dining_facilities/_dining_facility.json.jbuilder b/app/views/api/dining_facilities/_dining_facility.json.jbuilder new file mode 100644 index 00000000..1f6d743b --- /dev/null +++ b/app/views/api/dining_facilities/_dining_facility.json.jbuilder @@ -0,0 +1,3 @@ +if dining_facility + json.name dining_facility.name +end diff --git a/app/views/api/foodcourt/bills/create.json.jbuilder b/app/views/api/foodcourt/bills/create.json.jbuilder new file mode 100644 index 00000000..70ced95a --- /dev/null +++ b/app/views/api/foodcourt/bills/create.json.jbuilder @@ -0,0 +1,26 @@ +if @status == true + #show invoice number and stuff + json.status @status + json.sale_id @sale_data.sale_id + sale = Sale.find(@sale_data.sale_id) + + json.sale_items sale.sale_items do |sale_item| + json.sale_item_id sale_item.sale_item_id + json.sale_id sale_item.sale_id + json.product_code sale_item.product_code + json.item_instance_code sale_item.item_instance_code + json.product_name sale_item.product_name + json.product_alt_name sale_item.product_alt_name + json.account_id sale_item.account_id + json.status sale_item.status + json.remark sale_item.remark + json.qty sale_item.qty + json.unit_price sale_item.unit_price + json.taxable_price sale_item.taxable_price + json.price sale_item.price + json.is_taxable sale_item.is_taxable + end +else + json.status @status + json.error_message @error_message +end diff --git a/app/views/api/foodcourt/orders/create.json.jbuilder b/app/views/api/foodcourt/orders/create.json.jbuilder new file mode 100644 index 00000000..664b700d --- /dev/null +++ b/app/views/api/foodcourt/orders/create.json.jbuilder @@ -0,0 +1,26 @@ +if @status == true + json.status @status + json.id @order.id + json.booking_id @booking.id + json.order_items do + json.array! @order.order_items, :item_code, :item_name, :qty, :options, :remark,:price + end + if @sale + json.sale_id @sale.sale_id + json.sale_items do + json.array! @sale.sale_items, :product_name, :qty, :remark,:unit_price,:price + end + json.grand_total @sale.grand_total + json.total_tax @sale.total_tax + json.taxes do + json.array! @sale.sale_taxes, :tax_name, :tax_rate, :tax_payable_amount, :inclusive + end + end +else + json.status @status + if @error_messages + json.error_messages @error_messages + else + json.error_messages @message + end +end diff --git a/app/views/api/payments/create_paymal_payment.json.jbuilder b/app/views/api/foodcourt/payments/create.json.jbuilder similarity index 94% rename from app/views/api/payments/create_paymal_payment.json.jbuilder rename to app/views/api/foodcourt/payments/create.json.jbuilder index e06209db..36ca0e03 100644 --- a/app/views/api/payments/create_paymal_payment.json.jbuilder +++ b/app/views/api/foodcourt/payments/create.json.jbuilder @@ -9,6 +9,10 @@ json.data do json.booking @sale.booking.booking_id + if @sale.booking.dining_facility + json.dining_facility @sale.booking.dining_facility.name + end + json.shop do json.name current_shop.name json.address current_shop.address diff --git a/app/views/api/foodcourt/void/create.json.jbuilder b/app/views/api/foodcourt/void/create.json.jbuilder new file mode 100644 index 00000000..ce3f505d --- /dev/null +++ b/app/views/api/foodcourt/void/create.json.jbuilder @@ -0,0 +1,61 @@ +#show invoice number and stuff +json.status @status +json.message @message + +json.data do + if @status + json.sale_id @sale.sale_id + json.sale_status @sale.sale_status + + json.booking @sale.booking.booking_id + + if @sale.booking.dining_facility + json.dining_facility @sale.booking.dining_facility.name + end + + json.shop do + json.name current_shop.name + json.address current_shop.address + json.phone_no current_shop.phone_no + end + + order = @sale.orders.first + + json.order do + json.order_no order.order_id + json.order_by order.waiters + json.order_date order.date + end + + json.cashier_name @sale.cashier_name + json.receipt_no @sale.receipt_no + json.receipt_date @sale.receipt_date + json.sub_total @sale.total_amount + json.discount_type @sale.discount_type + json.total_discount @sale.total_discount + + json.sale_taxes @sale.sale_taxes do |sale_tax| + json.display_name sale_tax.display_name + json.tax_amount sale_tax.tax_payable_amount + end + + json.grand_total @sale.grand_total + + json.sale_items @sale.sale_items do |sale_item| + json.sale_item_id sale_item.sale_item_id + json.sale_id sale_item.sale_id + json.product_code sale_item.product_code + json.item_instance_code sale_item.item_instance_code + json.product_name sale_item.product_name + json.product_alt_name sale_item.product_alt_name + json.account_id sale_item.account_id + json.status sale_item.status + json.remark sale_item.remark + json.qty sale_item.qty + json.unit_price sale_item.unit_price + json.taxable_price sale_item.taxable_price + json.price sale_item.price + json.is_taxable sale_item.is_taxable + end + end +end diff --git a/app/views/api/order_items/_order_item.json.jbuilder b/app/views/api/order_items/_order_item.json.jbuilder new file mode 100644 index 00000000..f56f224c --- /dev/null +++ b/app/views/api/order_items/_order_item.json.jbuilder @@ -0,0 +1,19 @@ +if order_item + json.order_item_id order_item.order_items_id + + json.item_code order_item.item_code + + json.item_instance_code order_item.item_instance_code + + json.item_name order_item.item_name + + json.qty order_item.qty + + json.price order_item.price + + json.options order_item.options + + json.set_menu_items order_item.set_menu_items + + json.remark order_item.remark +end diff --git a/app/views/api/orders/_order.json.jbuilder b/app/views/api/orders/_order.json.jbuilder new file mode 100644 index 00000000..e4bfd4d9 --- /dev/null +++ b/app/views/api/orders/_order.json.jbuilder @@ -0,0 +1,15 @@ +if order + json.order_id order.order_id + + json.date order.date.try(:utc) + + json.source order.source + + json.customer_id order.customer_id + + json.customer_name order.try(:customer).try(:name) + + json.order_by order.waiters + + json.order_items order.order_items, partial: "api/order_items/order_item", as: :order_item +end diff --git a/app/views/api/sale_items/_sale_item.json.jbuilder b/app/views/api/sale_items/_sale_item.json.jbuilder new file mode 100644 index 00000000..b552cd47 --- /dev/null +++ b/app/views/api/sale_items/_sale_item.json.jbuilder @@ -0,0 +1,8 @@ +if sale_item + json.product_name sale_item.product_name + json.product_alt_name sale_item.product_alt_name + json.qty sale_item.qty + json.unit_price sale_item.unit_price + json.price sale_item.price + json.taxable_price sale_item.taxable_price +end diff --git a/app/views/api/sale_taxes/_sale_tax.json.jbuilder b/app/views/api/sale_taxes/_sale_tax.json.jbuilder new file mode 100644 index 00000000..84b7dc84 --- /dev/null +++ b/app/views/api/sale_taxes/_sale_tax.json.jbuilder @@ -0,0 +1,6 @@ +if sale_tax + json.tax_name sale_tax.tax_name + json.tax_rate sale_tax.tax_rate + json.tax_payable_amount sale_tax.tax_payable_amount + json.inclusive sale_tax.inclusive +end diff --git a/app/views/api/sales/_sale.json.jbuilder b/app/views/api/sales/_sale.json.jbuilder new file mode 100644 index 00000000..501551fa --- /dev/null +++ b/app/views/api/sales/_sale.json.jbuilder @@ -0,0 +1,32 @@ +if sale + json.sale_id sale.id + json.cashier_name sale.cashier_name + json.receipt_no sale.receipt_no + json.receipt_date sale.receipt_date.try(:utc) + + json.customer_id sale.customer_id + json.customer_name sale.try(:customer).try(:name) + + json.sale_status sale.sale_status + + json.total_amount sale.total_amount + + json.discount_type sale.discount_type.capitalize + json.total_discount sale.total_discount + + json.tax_type sale.tax_type + json.total_tax sale.total_tax + + json.grand_total sale.grand_total + + json.rounding_adjustment sale.rounding_adjustment + + json.amount_received sale.amount_received + json.amount_changed sale.amount_changed + + json.shift_sale_id sale.shift_sale_id + + json.sale_items sale.sale_items, partial: "api/sale_items/sale_item", as: :sale_item + + json.sale_taxes sale.sale_taxes, partial: "api/sale_taxes/sale_tax", as: :sale_tax +end diff --git a/app/views/api/shifts/update.json.jbuilder b/app/views/api/shifts/update.json.jbuilder new file mode 100644 index 00000000..1fd0659e --- /dev/null +++ b/app/views/api/shifts/update.json.jbuilder @@ -0,0 +1,126 @@ +json.status @status +json.message @message + +if @status + json.data do + json.shop do + json.name current_shop.name + json.address current_shop.address + json.phone_no current_shop.phone_no + end + + json.cashier @shift.employee.name + json.cashier_station @shift.cashier_terminal.name + json.opening_date @shift.shift_started_at.strftime('%d-%m-%Y %I:%M %p') + json.closing_date @shift.shift_closed_at.strftime('%d-%m-%Y %I:%M %p') + json.opening_float @shift.opening_balance + json.closing_float @shift.closing_balance + + json.sale_by_payments do + json.child! do + json.name 'Cash' + json.total_amount @shift.credit_sales + end + json.child! do + json.name 'Credit' + json.total_amount @shift.credit_sales + end + + @payment_methods.each do |payment_method| + json.child! do + json.name payment_method + json.total_amount @other_payment.first[payment_method.parameterize.to_sym] + end + end + end + + json.rounding_adjustment @shift.total_rounding + json.total @shift.grand_total + + json.sale_taxes @sale_taxes do |sale_tax| + json.tax_name sale_tax.tax_name + json.tax_amount sale_tax.st_amount + end + + json.total_taxes @shift.total_taxes + json.nett_sales @shift.nett_sales + + json.total_credit_payment @total_credit_payments + + json.sale_discounts do + @total_discount_by_account.each do |account| + json.child! do + json.name account.account_name + json.total_amount account.total_price + end + end + + if @total_member_discount && @total_member_discount.first.member_discount + json.child! do + json.name "Member" + json.total_amount @total_member_discount.first.member_discount + end + elsif @total_discount_by_account.size < 1 + json.array! + end + end + + json.total_discount @shift.total_discounts + + json.total_foc @other_payment.first.foc_amount + json.total_void @shift.total_void.to_d + json.total_waste @total_waste + json.total_spoile @total_spoile + + json.sale_by_accounts @total_amount_by_account do |account| + json.name account.account_name + json.total_amount account.total_price + end + + json.total_other_amount @total_other_charges + json.total_dine_in_count @shift.dining_count + json.total_takeaway_count @shift.takeaway_count + json.total_receipts @shift.total_receipt + + if @sale_items.present? + json.sale_items_summary do + total_items = 0 + total_amount = BigDecimal("0.0") + json.sale_items_groups do + @sale_items.group_by(&:menu_category_name).each do |menu| + json.child! do + json.category_name menu[0] + json.sale_items menu[1] do |item| + json.product_name item.product_name + json.unit_price item.unit_price + json.total_qty item.total_item + json.total_price item.grand_total + + total_items += item.total_item + total_amount += item.grand_total + end + end + end + + unless @total_other_charges_info.nil? + json.child! do + json.category_name 'Other Charges' + json.sale_items @total_other_charges_info do |item| + json.product_name item.product_name + json.unit_price item.unit_price + json.total_qty item.total_item + json.total_price item.grand_total + + total_items += item.total_item + total_amount += item.grand_total + end + end + end + end + + json.total_items total_items + json.total_amount total_amount + end + end + end +end diff --git a/config/routes.rb b/config/routes.rb index 945adc42..4abb2ab6 100755 --- a/config/routes.rb +++ b/config/routes.rb @@ -49,6 +49,8 @@ scope "(:locale)", locale: /en|mm/ do post 'authenticate' => "authenticate#create" delete 'authenticate' => "authenticate#destroy" + post 'check_emp_access_code' => 'authenticate#check_emp_access_code' + resources :shops, only: [:index, :show] resources :verifications, only: [:new] get 'get_tax_profiles' => "shops#get_tax_profiles" @@ -86,8 +88,19 @@ scope "(:locale)", locale: /en|mm/ do post "update_order_item" => "orders#update" #Current active bookings - resources :bookings, only: [:index, :show, :create, :update] + resources :bookings, only: [:show] do + collection do + get 'pending' + get 'billed' + get 'completed' + get 'void' + end + end + + get "customers/get_by_account" => "customers#get_customer_by_account" + resources :customers + # get customer by phone get "get_customer_by_phone" => "customers#get_customer_by_phone" #get customer details by order items @@ -126,13 +139,14 @@ scope "(:locale)", locale: /en|mm/ do post "sound_effect" => "sound_effect#sound_effect" + resources :sales, only: [:show] + #API for cashier app post 'authenticate_cashier' => "authenticate#create_cashier" post "shifts/new" => "shifts#create" post "shifts/close" => "shifts#update" post "request_bill" => "bill#request_bill" post "paymal_payment" => "payments#paymal_payment" - post "create_paymal_payment" => "payments#create_paymal_payment" get ":sale_id/void" => "void#overall_void" #API for sync cloud @@ -150,6 +164,14 @@ scope "(:locale)", locale: /en|mm/ do get "search_paypar_account_no" => "payments#search_paypar_account_no" # get "check_security_code" => "payments#check_security_code" + namespace :foodcourt do + resources :bills, only: [:create] + resources :orders, only: [:create] + resources :payments, only: [:create] + resources :void, only: [:create] + end + + #for display image get "display_image/:shop_code" => "display_images#display_image", as:'display_image' end