merge crm
This commit is contained in:
@@ -18,3 +18,4 @@
|
|||||||
//= require cable
|
//= require cable
|
||||||
//= require settings/processing_items
|
//= require settings/processing_items
|
||||||
//= require bootstrap-datepicker
|
//= require bootstrap-datepicker
|
||||||
|
|
||||||
|
|||||||
@@ -4,10 +4,13 @@ class Crm::CustomersController < ApplicationController
|
|||||||
# GET /crm/customers
|
# GET /crm/customers
|
||||||
# GET /crm/customers.json
|
# GET /crm/customers.json
|
||||||
def index
|
def index
|
||||||
@crm_customers = Customer.all
|
@sale_id = 0
|
||||||
@customers = Customer.new
|
@crm_customers = Customer.all
|
||||||
|
@crm_customer = Customer.new
|
||||||
@membership = Customer.get_member_group
|
@membership = Customer.get_member_group
|
||||||
|
if @membership["status"] == true
|
||||||
|
@member_group = @membership["data"]
|
||||||
|
end
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
format.html # index.html.erb
|
format.html # index.html.erb
|
||||||
format.json { render json: @crm_customers }
|
format.json { render json: @crm_customers }
|
||||||
@@ -33,15 +36,68 @@ class Crm::CustomersController < ApplicationController
|
|||||||
# POST /crm/customers
|
# POST /crm/customers
|
||||||
# POST /crm/customers.json
|
# POST /crm/customers.json
|
||||||
def create
|
def create
|
||||||
@crm_customer = Customer.new(customer_params)
|
|
||||||
|
|
||||||
|
@crm_customers = Customer.new(customer_params)
|
||||||
|
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
if @crm_customer.save
|
if @crm_customers.save
|
||||||
format.html { redirect_to @crm_customer, notice: 'Customer was successfully created.' }
|
|
||||||
format.json { render :show, status: :created, location: @crm_customer }
|
|
||||||
|
name = customer_params[:name]
|
||||||
|
phone = customer_params[:contact_no]
|
||||||
|
email = customer_params[:email]
|
||||||
|
date_of_birth = customer_params[:date_of_birth]
|
||||||
|
membership_id = params[:membership_id]
|
||||||
|
|
||||||
|
membership = MembershipSetting.find_by_membership_type("smartpay_url")
|
||||||
|
app_token = membership.auth_token.to_s
|
||||||
|
url = membership.gateway_url.to_s + "/api/create_membership_customer".to_s
|
||||||
|
|
||||||
|
response = HTTParty.post(url, :body => { name: name,phone: phone,email: email,
|
||||||
|
date_of_birth: date_of_birth,
|
||||||
|
membership_id: membership_id}.to_json,
|
||||||
|
:headers => {
|
||||||
|
'Content-Type' => 'application/json',
|
||||||
|
'Accept' => 'application/json'
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
if response["status"] == true
|
||||||
|
puts "hhhhhhhhhhhhhhhhhh"
|
||||||
|
puts params[:sale_id]
|
||||||
|
customer = Customer.find(@crm_customers.customer_id)
|
||||||
|
status = customer.update_attributes(membership_id: response["customer_datas"]["id"])
|
||||||
|
if params[:sale_id] != 0
|
||||||
|
format.html { redirect_to crm_customers_path, notice: 'Customer was successfully created.' }
|
||||||
|
else
|
||||||
|
format.html { redirect_to '/crm/customers/'+params[:sale_id]+'/assign_sale_id', notice: 'Customer was successfully created.' }
|
||||||
|
end
|
||||||
|
# format.json { render :index, status: :created, location: @crm_customers }
|
||||||
|
else
|
||||||
|
|
||||||
|
@crm_customers.destroy
|
||||||
|
|
||||||
|
if params[:sale_id] != 0
|
||||||
|
format.html { redirect_to crm_customers_path, notice: response["message"] }
|
||||||
|
|
||||||
|
else
|
||||||
|
format.html { redirect_to '/crm/customers/'+params[:sale_id]+'/assign_sale_id', notice: response["message"] }
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
# format.json { render :index, status: :created, location: @crm_customers }
|
||||||
|
|
||||||
else
|
else
|
||||||
format.html { render :new }
|
if params[:sale_id] != 0
|
||||||
format.json { render json: @crm_customer.errors, status: :unprocessable_entity }
|
format.html { redirect_to crm_customers_path}
|
||||||
|
format.json { render json: @crm_customers.errors, status: :unprocessable_entity }
|
||||||
|
|
||||||
|
else
|
||||||
|
format.html { redirect_to '/crm/customers/'+params[:sale_id]+'/assign_sale_id', notice: response["message"] }
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -49,14 +105,38 @@ class Crm::CustomersController < ApplicationController
|
|||||||
# PATCH/PUT /crm/customers/1
|
# PATCH/PUT /crm/customers/1
|
||||||
# PATCH/PUT /crm/customers/1.json
|
# PATCH/PUT /crm/customers/1.json
|
||||||
def update
|
def update
|
||||||
|
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
if @crm_customer.update(customer_params)
|
if @crm_customer.update(customer_params)
|
||||||
format.html { redirect_to @crm_customer, notice: 'Customer was successfully updated.' }
|
|
||||||
|
name = customer_params[:name]
|
||||||
|
phone = customer_params[:contact_no]
|
||||||
|
email = customer_params[:email]
|
||||||
|
date_of_birth = customer_params[:date_of_birth]
|
||||||
|
id = customer_params[:membership_id]
|
||||||
|
|
||||||
|
membership = MembershipSetting.find_by_membership_type("smartpay_url")
|
||||||
|
app_token = membership.auth_token.to_s
|
||||||
|
url = membership.gateway_url.to_s + "/api/update_membership_customer".to_s
|
||||||
|
|
||||||
|
response = HTTParty.post(url, :body => { name: name,phone: phone,email: email,
|
||||||
|
date_of_birth: date_of_birth,
|
||||||
|
id: id}.to_json,
|
||||||
|
:headers => {
|
||||||
|
'Content-Type' => 'application/json',
|
||||||
|
'Accept' => 'application/json'
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
format.html { redirect_to crm_customers_path, notice: 'Customer was successfully updated.' }
|
||||||
format.json { render :show, status: :ok, location: @crm_customer }
|
format.json { render :show, status: :ok, location: @crm_customer }
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
||||||
format.html { render :edit }
|
format.html { render :edit }
|
||||||
format.json { render json: @crm_customer.errors, status: :unprocessable_entity }
|
format.json { render json: @crm_customer.errors, status: :unprocessable_entity }
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -70,6 +150,23 @@ class Crm::CustomersController < ApplicationController
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# DELETE /crm/customers/1
|
||||||
|
# DELETE /crm/customers/1.json
|
||||||
|
def get_sale_id
|
||||||
|
|
||||||
|
@sale_id = params[:sale_id]
|
||||||
|
@crm_customers = Customer.all
|
||||||
|
@crm_customer = Customer.new
|
||||||
|
@membership = Customer.get_member_group
|
||||||
|
if @membership["status"] == true
|
||||||
|
@member_group = @membership["data"]
|
||||||
|
end
|
||||||
|
respond_to do |format|
|
||||||
|
format.html { render action: "index"}
|
||||||
|
format.json { render json: @crm_customers }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
# Use callbacks to share common setup or constraints between actions.
|
# Use callbacks to share common setup or constraints between actions.
|
||||||
def set_crm_customer
|
def set_crm_customer
|
||||||
@@ -78,6 +175,9 @@ class Crm::CustomersController < ApplicationController
|
|||||||
|
|
||||||
# Never trust parameters from the scary internet, only allow the white list through.
|
# Never trust parameters from the scary internet, only allow the white list through.
|
||||||
def customer_params
|
def customer_params
|
||||||
params.require(:customer).permit(:name, :company, :contact_no, :email, :date_of_birth, :membership_id, :membership_type, :membership_authentication_code)
|
|
||||||
|
params.require(:customer).permit(:name, :company, :contact_no, :email, :date_of_birth, :membership_type, :membership_authentication_code)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -3,22 +3,38 @@ class Crm::HomeController < BaseCrmController
|
|||||||
|
|
||||||
@booking = Booking.all
|
@booking = Booking.all
|
||||||
@customer = Customer.all
|
@customer = Customer.all
|
||||||
|
|
||||||
#@booking = Booking.select("bookings.id as booking_id,
|
|
||||||
# bookings.checkin_at,
|
|
||||||
# bookings.checkin_by,
|
|
||||||
# bookings.dining_facility_id,
|
|
||||||
# od.customer_id as customer,
|
|
||||||
# od.id as order_id,
|
|
||||||
# od.item_count as count,
|
|
||||||
# odt.id as order_item_id,
|
|
||||||
# odt.item_name as item_name")
|
|
||||||
# .joins("join booking_orders as bko ON bko.booking_id = bookings.id")
|
|
||||||
# .joins("right join orders as od ON od.id = bko.order_id")
|
|
||||||
# .joins("right join order_items as odt ON odt.order_id=od.id")
|
|
||||||
# .order("bookings.id DESC")
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def show
|
def show
|
||||||
end
|
end
|
||||||
|
|
||||||
|
#print for crm
|
||||||
|
def print_order
|
||||||
|
|
||||||
|
@booking = Booking.find(params[:id])
|
||||||
|
unique_code="CrmOrderPdf"
|
||||||
|
|
||||||
|
print_settings = PrintSetting.find_by_unique_code(unique_code)
|
||||||
|
|
||||||
|
printer = Printer::ReceiptPrinter.new(print_settings)
|
||||||
|
|
||||||
|
printer.print_crm_order(@booking,print_settings)
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
def update_sale_by_customer
|
||||||
|
|
||||||
|
sale = Sale.find(params[:sale_id])
|
||||||
|
status = sale.update_attributes(customer_id: params[:customer_id])
|
||||||
|
|
||||||
|
if status == true
|
||||||
|
render json: JSON.generate({:status => true})
|
||||||
|
else
|
||||||
|
render json: JSON.generate({:status => false, :error_message => "Record not found"})
|
||||||
|
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
class Origami::RequestBillsController < BaseOrigamiController
|
class Origami::RequestBillsController < BaseOrigamiController
|
||||||
|
|
||||||
|
|
||||||
def print
|
def print
|
||||||
@sale = Sale.new
|
@sale = Sale.new
|
||||||
sale_order=SaleOrder.new
|
sale_order=SaleOrder.new
|
||||||
@@ -25,4 +26,4 @@ class Origami::RequestBillsController < BaseOrigamiController
|
|||||||
printer.print_receipt_bill(print_settings,@sale_items,@sale_data,customer_name)
|
printer.print_receipt_bill(print_settings,@sale_items,@sale_data,customer_name)
|
||||||
redirect_to origami_root_path
|
redirect_to origami_root_path
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ class Account < ApplicationRecord
|
|||||||
validates_presence_of :title, :account_type
|
validates_presence_of :title, :account_type
|
||||||
|
|
||||||
has_many :menu_items
|
has_many :menu_items
|
||||||
# belongs_to :lookup , :class_name => "Lookup"
|
|
||||||
def self.collection
|
def self.collection
|
||||||
Account.select("id, title").map { |e| [e.title, e.id] }
|
Account.select("id, title").map { |e| [e.title, e.id] }
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -10,21 +10,26 @@ class Customer < ApplicationRecord
|
|||||||
validates :contact_no, uniqueness: true
|
validates :contact_no, uniqueness: true
|
||||||
validates :email, uniqueness: true
|
validates :email, uniqueness: true
|
||||||
|
|
||||||
|
|
||||||
def self.get_member_group
|
def self.get_member_group
|
||||||
|
|
||||||
gateway_url = MembershipSetting.find_by_membership_type("smartpay_url")
|
membership = MembershipSetting.find_by_membership_type("smartpay_url")
|
||||||
url = gateway_url.gateway_url.to_s + "/api/get_all_member_group".to_s
|
app_token = membership.auth_token.to_s
|
||||||
response = HTTParty.get(url)
|
|
||||||
|
url = membership.gateway_url.to_s + "/api/get_all_member_group".to_s
|
||||||
|
response = HTTParty.get(url,
|
||||||
|
:body => { app_token: app_token}.to_json,
|
||||||
|
:headers => {
|
||||||
|
'Content-Type' => 'application/json',
|
||||||
|
'Accept' => 'application/json'
|
||||||
|
}
|
||||||
|
)
|
||||||
puts response.body, response.code, response.message, response.headers.inspect
|
puts response.body, response.code, response.message, response.headers.inspect
|
||||||
|
|
||||||
return response;
|
return response;
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# http://192.168.1.47:3006/api/create_membership_customer
|
|
||||||
#get_all_member_group
|
|
||||||
|
|
||||||
|
|
||||||
def lastest_invoices
|
def lastest_invoices
|
||||||
sales.where(:customer_id => self.id).order("created_at desc").limit(5)
|
sales.where(:customer_id => self.id).order("created_at desc").limit(5)
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -72,4 +72,14 @@ class Printer::ReceiptPrinter < Printer::PrinterWorker
|
|||||||
pdf.render_file "tmp/receipt_bill.pdf"
|
pdf.render_file "tmp/receipt_bill.pdf"
|
||||||
self.print("tmp/receipt_bill.pdf")
|
self.print("tmp/receipt_bill.pdf")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
#Bill Receipt Print
|
||||||
|
def print_crm_order(booking,setting)
|
||||||
|
#Use CUPS service
|
||||||
|
#Generate PDF
|
||||||
|
#Print
|
||||||
|
pdf = CrmOrderPdf.new(booking,setting)
|
||||||
|
pdf.render_file "tmp/print_crm_order.pdf"
|
||||||
|
self.print("tmp/print_crm_order.pdf")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
71
app/pdf/crm_order_pdf.rb
Normal file
71
app/pdf/crm_order_pdf.rb
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
class CrmOrderPdf < Prawn::Document
|
||||||
|
|
||||||
|
def initialize(order_item, print_settings)
|
||||||
|
super(:margin => [10, 5, 30, 5], :page_size => [200,400])
|
||||||
|
|
||||||
|
# font "public/fonts/#{font_name}".to_s + ".ttf".to_s
|
||||||
|
# font "public/fonts/Zawgyi-One.ttf"
|
||||||
|
# font "public/fonts/padauk.ttf"
|
||||||
|
font_size 9
|
||||||
|
text "#{order_item.type}", :size => 15
|
||||||
|
stroke_horizontal_rule
|
||||||
|
move_down 5
|
||||||
|
|
||||||
|
#order_info
|
||||||
|
order_info(order_item.checkin_by,order_item.checkin_at, order_item.customer_id)
|
||||||
|
|
||||||
|
# order items
|
||||||
|
order_items(order_item)
|
||||||
|
end
|
||||||
|
|
||||||
|
# Write Order Information to PDF
|
||||||
|
def order_info(order_by, order_at, customer)
|
||||||
|
y_position = cursor
|
||||||
|
|
||||||
|
bounding_box([0,y_position], :width => 200, :height => 15) do
|
||||||
|
text "OrderBy:#{order_by} Customer:#{customer} Date:#{order_at.strftime("%Y-%m-%d")}", :size => 7,:align => :left
|
||||||
|
end
|
||||||
|
|
||||||
|
stroke_horizontal_rule
|
||||||
|
|
||||||
|
move_down 20
|
||||||
|
end
|
||||||
|
|
||||||
|
# Write Order items to PDF
|
||||||
|
def order_items(order_item)
|
||||||
|
y_position = cursor
|
||||||
|
|
||||||
|
bounding_box([0,y_position], :width => 180, :height => 15) do
|
||||||
|
text "Item", :size => 7,:align => :left
|
||||||
|
end
|
||||||
|
|
||||||
|
bounding_box([160,y_position], :width => 20, :height => 15) do
|
||||||
|
text "Qty", :size => 7,:align => :right
|
||||||
|
end
|
||||||
|
|
||||||
|
stroke_horizontal_rule
|
||||||
|
move_down 5
|
||||||
|
|
||||||
|
#Add Order Item
|
||||||
|
add_order_items(order_item)
|
||||||
|
end
|
||||||
|
|
||||||
|
# Add order items under order info
|
||||||
|
def add_order_items(order_item)
|
||||||
|
y_position = cursor
|
||||||
|
|
||||||
|
move_down 5
|
||||||
|
|
||||||
|
bounding_box([0,y_position], :width => 180, :height => 20) do
|
||||||
|
text "#{order_item.sale_id}", :size => 7,:align => :left
|
||||||
|
end
|
||||||
|
|
||||||
|
bounding_box([160,y_position], :width => 20, :height => 20) do
|
||||||
|
text "#{order_item.sale_id}", :size => 7,:align => :right
|
||||||
|
end
|
||||||
|
|
||||||
|
move_down 5
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
@@ -8,7 +8,6 @@
|
|||||||
<%= f.input :contact_no %>
|
<%= f.input :contact_no %>
|
||||||
<%= f.input :email %>
|
<%= f.input :email %>
|
||||||
<%= f.input :date_of_birth %>
|
<%= f.input :date_of_birth %>
|
||||||
<%= f.input :membership_id, :collection => @membership %>
|
|
||||||
<%= f.input :membership_type %>
|
<%= f.input :membership_type %>
|
||||||
<%= f.input :membership_authentication_code %>
|
<%= f.input :membership_authentication_code %>
|
||||||
</div>
|
</div>
|
||||||
@@ -17,3 +16,5 @@
|
|||||||
<%= f.button :submit %>
|
<%= f.button :submit %>
|
||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
<!-- -->
|
||||||
|
|
||||||
@@ -1,20 +1,20 @@
|
|||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-lg-12">
|
<div class="col-lg-12">
|
||||||
<ol class="breadcrumb">
|
<ol class="breadcrumb">
|
||||||
<li><a href="<%= dashboard_path %>">Home</a></li>
|
<li><a href="<%= crm_root_path %>">Home</a></li>
|
||||||
<li class="active">
|
<li class="active">
|
||||||
<a href="<%= crm_customers_path %>">Customer</a>
|
<a href="<%= crm_customers_path %>">Customer</a>
|
||||||
</li>
|
</li>
|
||||||
<a href="<%= new_crm_customer_path%>" class="btn btn-primary pull-right">
|
<!-- <a href="<%= new_crm_customer_path%>" class="btn btn-primary pull-right">
|
||||||
<i class="fa fa-plus-circle fa-lg"></i> Add Customer
|
<i class="fa fa-plus-circle fa-lg"></i> Add Customer
|
||||||
</a>
|
</a> -->
|
||||||
</ol>
|
</ol>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<br/>
|
<br/>
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-lg-7">
|
<div class="col-lg-8">
|
||||||
|
|
||||||
<div class="main-box-body clearfix">
|
<div class="main-box-body clearfix">
|
||||||
<div class="table-responsive">
|
<div class="table-responsive">
|
||||||
@@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
|
<th>Select</th>
|
||||||
<th>Name</th>
|
<th>Name</th>
|
||||||
<th>Company</th>
|
<th>Company</th>
|
||||||
<th>Contact no</th>
|
<th>Contact no</th>
|
||||||
@@ -32,10 +33,16 @@
|
|||||||
<tbody>
|
<tbody>
|
||||||
<% @crm_customers.each do |crm_customer| %>
|
<% @crm_customers.each do |crm_customer| %>
|
||||||
<tr>
|
<tr>
|
||||||
|
<td>
|
||||||
|
<input type="radio" style="width:20px;" value="<%= crm_customer.customer_id %>" name="checkbox" class="checkbox_check" ></td>
|
||||||
<td><%= crm_customer.name %></td>
|
<td><%= crm_customer.name %></td>
|
||||||
<td><%= crm_customer.company %></td>
|
<td><%= crm_customer.company %></td>
|
||||||
<td><%= crm_customer.contact_no %></td>
|
<td><%= crm_customer.contact_no %></td>
|
||||||
<td><%= crm_customer.email %></td>
|
<td><%= crm_customer.email %></td>
|
||||||
|
<td>
|
||||||
|
<%= link_to 'Destroy', crm_customer_path(crm_customer), method: :delete, data: { confirm: 'Are you sure?' } %>
|
||||||
|
|
||||||
|
</td>
|
||||||
|
|
||||||
</tr>
|
</tr>
|
||||||
<% end %>
|
<% end %>
|
||||||
@@ -46,55 +53,61 @@
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-lg-5">
|
<div class="col-lg-4">
|
||||||
<%= simple_form_for crm_customers_path, :html => { :class => 'form-horizontal' } do |f| %>
|
<%= simple_form_for @crm_customer,:url => crm_customers_path, :method => :post do |f| %>
|
||||||
|
<span class="patch_method"></span>
|
||||||
|
<input type="hidden" id="sale_id" name="sale_id" value="<%= @sale_id %>" />
|
||||||
|
<%= f.hidden_field :id, :class => "form-control col-md-6 " %>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<%= f.input :name, :class => "form-control col-md-6" %>
|
<%= f.input :name, :class => "form-control col-md-6 name" %>
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<%= f.input :company, :class => "form-control col-md-6" %>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<%= f.input :contact_no, :class => "form-control col-md-6" %>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<%= f.input :email, :class => "form-control col-md-6" %>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="date_of_birth" class="col-md-6 control-label">Date Of Birth</label>
|
<%= f.input :company, :class => "form-control col-md-6 company" %>
|
||||||
<%= f.text_field :date_of_birth,:class=>"form-control datepicker",:readonly =>true, :value => @date_of_birth%>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<%= f.input :contact_no, :class => "form-control col-md-6 contact_no" %>
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<%= f.input :email, :class => "form-control col-md-6 email" %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label>Date Of Birth</label>
|
||||||
|
<%= f.text_field :date_of_birth,:class=>"form-control datepicker date_of_birth",:readonly =>true, :value => @date_of_birth%>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<%= f.select :membership_id, options_for_select(@membership.collect { |member|
|
<select class="selectpicker form-control col-md-12" name="membership_id">
|
||||||
[member["id"].name.titleize, member["id"].id] }, 1), {}, { id: 'countries_select' } %>
|
|
||||||
<select class="selectpicker form-control col-md-6" name="membership_id">
|
|
||||||
<option>Select Member Group</option>
|
<option>Select Member Group</option>
|
||||||
<% @membership.each do |member| %>
|
<% @member_group.each do |member| %>
|
||||||
<option value="<%= member["id"] %>">
|
<option value="<%= member["id"] %>">
|
||||||
<%= member["name"] %></option>
|
<%= member["name"] %></option>
|
||||||
<%end %>
|
<%end %>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<%= f.input :membership_type, :class => "form-control col-md-6" %>
|
<%= f.input :membership_type, :class => "form-control col-md-6 membership_type" %>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<%= f.input :membership_authentication_code, :class => "form-control col-md-6" %>
|
<%= f.input :membership_authentication_code, :class => "form-control col-md-6 membership_authentication_code" %>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<%= f.button :submit, "Submit", :class => 'btn btn-primary' , :id => 'submit_account' %>
|
<%= f.button :submit, "Submit",:class => 'btn btn-primary ', :id => 'submit_customer' %>
|
||||||
|
<%= f.button :submit, "Update",:class => 'btn btn-primary ', :disabled =>'', :id => 'update_customer' %>
|
||||||
</div>
|
</div>
|
||||||
<%end%>
|
<%end%>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jquery-confirm/3.2.0/jquery-confirm.min.css">
|
||||||
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-confirm/3.2.0/jquery-confirm.min.js"></script>
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
$(function () {
|
$(function () {
|
||||||
if (jQuery().datepicker) {
|
if (jQuery().datepicker) {
|
||||||
@@ -107,4 +120,112 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$(document).on('click',".checkbox_check",function(){
|
||||||
|
if(this.checked){
|
||||||
|
|
||||||
|
var sale_id = $("#sale_id").val() || 0;
|
||||||
|
var customer_id = $(this).val();
|
||||||
|
|
||||||
|
if(sale_id != 0){
|
||||||
|
var url = "../"+customer_id;
|
||||||
|
update_sale(customer_id,sale_id);
|
||||||
|
}else{
|
||||||
|
|
||||||
|
var url = "customers/"+customer_id;
|
||||||
|
}
|
||||||
|
|
||||||
|
$.ajax({
|
||||||
|
type: "GET",
|
||||||
|
url: url,
|
||||||
|
data: {},
|
||||||
|
dataType: "json",
|
||||||
|
success: function(data) {
|
||||||
|
$('#customer_id').val(data.id);
|
||||||
|
$('#customer_name').val(data.name);
|
||||||
|
$('#customer_company').val(data.company);
|
||||||
|
$('#customer_contact_no').val(data.contact_no);
|
||||||
|
$('#customer_email').val(data.email);
|
||||||
|
$('#customer_date_of_birth').val(data.date_of_birth);
|
||||||
|
$('#customer_membership_type').val(data.membership_type);
|
||||||
|
$('.select > option[value="'+data.membership_id+'"]').attr('selected','selected');
|
||||||
|
$('.membership_authentication_code').val(data.membership_authentication_code);
|
||||||
|
|
||||||
|
$('#update_customer').removeAttr('disabled').val('');
|
||||||
|
$('#update_customer').attr('value', 'Update');
|
||||||
|
$('#submit_customer').attr('disabled','disabled');
|
||||||
|
|
||||||
|
$("#new_customer").attr('class', 'simple_form edit_customer');
|
||||||
|
var id = "edit_customer_"+$('#customer_id').val();
|
||||||
|
$("#new_customer").attr('id', id);
|
||||||
|
$(".edit_customer").attr('action', '/crm/customers/' + $('#customer_id').val());
|
||||||
|
$(".edit_customer").attr('action', '/crm/customers/' + $('#customer_id').val());
|
||||||
|
$(".patch_method").append('<input type="hidden" name="_method" value="patch">');
|
||||||
|
//$(".edit_customer").attr('method', 'PATCH');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}else{
|
||||||
|
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
function update_sale(customer_id,sale_id) {
|
||||||
|
$.confirm({
|
||||||
|
title: 'Confirm!',
|
||||||
|
content: 'Are You Sure to assign this customer!',
|
||||||
|
buttons: {
|
||||||
|
|
||||||
|
cancel: function () {
|
||||||
|
|
||||||
|
},
|
||||||
|
confirm: {
|
||||||
|
text: 'Confirm',
|
||||||
|
btnClass: 'btn-green',
|
||||||
|
keys: ['enter', 'shift'],
|
||||||
|
action: function(){
|
||||||
|
$.ajax({
|
||||||
|
type: "POST",
|
||||||
|
url: "../../update_sale/" ,
|
||||||
|
data: {customer_id:customer_id,sale_id:sale_id},
|
||||||
|
dataType: "json",
|
||||||
|
success: function(data) {
|
||||||
|
if(data.status == true)
|
||||||
|
{
|
||||||
|
alert('Customer has assigned');
|
||||||
|
window.location.href = '/origami'
|
||||||
|
}else{
|
||||||
|
alert('Record not found!');
|
||||||
|
location.reload();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*function changeMethod() {
|
||||||
|
$("#update_customer").attr('method', 'put');
|
||||||
|
}*/
|
||||||
|
|
||||||
|
|
||||||
|
/* $("#update_customer").click(function() {
|
||||||
|
$("#new_customer").attr('class', 'edit_customer');
|
||||||
|
var id = "edit_customer_"+$('#customer_id').val();alert(id);
|
||||||
|
$("#new_customer").attr('id', id);
|
||||||
|
alert(";;")
|
||||||
|
//$('#new_customer').removeClass('new_customer');
|
||||||
|
//$('#new_customer').addClass('edit_customer')
|
||||||
|
}); */
|
||||||
|
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -25,10 +25,6 @@
|
|||||||
<%= @crm_customer.date_of_birth %>
|
<%= @crm_customer.date_of_birth %>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
|
||||||
<strong>Membership:</strong>
|
|
||||||
<%= @crm_customer.membership %>
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
<strong>Membership type:</strong>
|
<strong>Membership type:</strong>
|
||||||
|
|||||||
@@ -1 +1,2 @@
|
|||||||
json.partial! "crm_customers/crm_customer", crm_customer: @crm_customer
|
json.extract! @crm_customer, :id, :name, :company, :contact_no, :email, :date_of_birth, :membership_id, :membership_type, :membership_authentication_code, :created_at, :updated_at
|
||||||
|
json.url crm_customer_url(@crm_customer, format: :json)
|
||||||
|
|||||||
@@ -4,9 +4,9 @@
|
|||||||
|
|
||||||
<% @i = 0 %>
|
<% @i = 0 %>
|
||||||
<% @booking.each do |booking| %>
|
<% @booking.each do |booking| %>
|
||||||
<% if booking.booking_status == "assign" %>
|
<% if booking.booking_status == "new" %>
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<div class="card-block booking_click" data-ref="<%= api_booking_path booking.id%>" id="card-block booking_block" style="width:100%;">
|
<div class="card-block booking_click" data-id="sfddf" data-ref="<%= api_booking_path booking.id%>" id="card-block booking_block" style="width:100%;" >
|
||||||
<h4 class="card-title">
|
<h4 class="card-title">
|
||||||
<%= @i += 1 %> . <%= booking.dining_facility.name %>
|
<%= @i += 1 %> . <%= booking.dining_facility.name %>
|
||||||
- <%= booking.id %>
|
- <%= booking.id %>
|
||||||
@@ -36,14 +36,21 @@
|
|||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
$(function(){
|
$(function(){
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
$(".booking_click").on("click", function(){
|
$(".booking_click").on("click", function(){
|
||||||
$(".summary-items tbody tr").remove();
|
$(".summary-items tbody tr").remove();
|
||||||
$("#cancel").removeAttr("disabled");
|
$("#cancel").removeAttr("disabled");
|
||||||
$("#assign").removeAttr("disabled");
|
$("#assign").removeAttr("disabled");
|
||||||
|
$("#crm_print").removeAttr("disabled");
|
||||||
|
//$("#crm_print").val($(this).attr('data'));
|
||||||
|
|
||||||
var url = $(this).attr('data-ref');
|
var url = $(this).attr('data-ref');
|
||||||
show_details(url);
|
show_details(url);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
$('.assign').click(function(e){
|
$('.assign').click(function(e){
|
||||||
var booking_id = $(this).val()
|
var booking_id = $(this).val()
|
||||||
var type = $(this).attr("data-type")
|
var type = $(this).attr("data-type")
|
||||||
@@ -58,6 +65,7 @@ $(function(){
|
|||||||
update_booking(booking_id,type)
|
update_booking(booking_id,type)
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
function show_details(url_item){
|
function show_details(url_item){
|
||||||
@@ -97,7 +105,7 @@ function show_details(url_item){
|
|||||||
function update_booking(booking_id,type) {
|
function update_booking(booking_id,type) {
|
||||||
$.ajax({
|
$.ajax({
|
||||||
type: "POST",
|
type: "POST",
|
||||||
url: "crm/update_booking/" ,
|
url: "update_booking/" ,
|
||||||
data: {booking_id:booking_id,type:type},
|
data: {booking_id:booking_id,type:type},
|
||||||
dataType: "json",
|
dataType: "json",
|
||||||
success: function(data) {
|
success: function(data) {
|
||||||
|
|||||||
@@ -92,10 +92,37 @@
|
|||||||
<!-- Column Three--->
|
<!-- Column Three--->
|
||||||
<div class="col-lg-1 col-md-1 col-sm-1">
|
<div class="col-lg-1 col-md-1 col-sm-1">
|
||||||
<!-- OQS Buttons -->
|
<!-- OQS Buttons -->
|
||||||
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Print</button>
|
<button id="crm_print" value="" disabled="disabled" data-type="assign" class="btn crm_print btn-primary btn-lg btn-block" >
|
||||||
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Print <br/>Order<br/>Summary</button>
|
Print
|
||||||
|
</button>
|
||||||
|
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Print <br/>Order<br/>Summary</button>
|
||||||
<button id="assign" value="" disabled="disabled" data-type="assign" class="btn assign btn-primary btn-lg btn-block">ASSIGN</button>
|
<button id="assign" value="" disabled="disabled" data-type="assign" class="btn assign btn-primary btn-lg btn-block">ASSIGN</button>
|
||||||
<button id="cancel" value="" disabled="disabled" data-type="cancel" class="btn btn-danger cancel btn-lg btn-block">CANCLE</button>
|
<button id="cancel" value="" disabled="disabled" data-type="cancel" class="btn btn-danger cancel btn-lg btn-block">CANCLE</button>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<script type="text/javascript">
|
||||||
|
|
||||||
|
$( document ).ready(function() {
|
||||||
|
$('.crm_print').click(function() {
|
||||||
|
var id = "BKI-000000000004"
|
||||||
|
$.ajax({
|
||||||
|
type: "GET",
|
||||||
|
url: "crm/print/"+id,
|
||||||
|
data: {},
|
||||||
|
dataType: "json",
|
||||||
|
success: function(data) {
|
||||||
|
/*if(data.status == true && data.type == "cancel")
|
||||||
|
{
|
||||||
|
alert('Booking has canceled!');
|
||||||
|
}else{
|
||||||
|
alert('Booking has completed!');
|
||||||
|
}
|
||||||
|
location.reload();*/
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|||||||
@@ -17,7 +17,7 @@
|
|||||||
<%= render 'layouts/header_crm' %>
|
<%= render 'layouts/header_crm' %>
|
||||||
<div class="container-fluid">
|
<div class="container-fluid">
|
||||||
<% flash.each do |type, message| %>
|
<% flash.each do |type, message| %>
|
||||||
<div class="alert fade in">
|
<div class="alert-danger fade in">
|
||||||
<button class="close" aria-hidden="true" data-dismiss="alert" type="button">×</button>
|
<button class="close" aria-hidden="true" data-dismiss="alert" type="button">×</button>
|
||||||
<%= message %>
|
<%= message %>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -206,15 +206,14 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div><p id="sale" value=""></p>
|
||||||
|
|
||||||
<!-- Column Three -->
|
<!-- Column Three -->
|
||||||
<div class="col-lg-1 col-md-1 col-sm-1">
|
<div class="col-lg-1 col-md-1 col-sm-1">
|
||||||
<!-- Waiter Buttons -->
|
<!-- Waiter Buttons -->
|
||||||
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Add Order</button>
|
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Add Order</button>
|
||||||
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Edit</button>
|
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Edit</button>
|
||||||
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Move</button>
|
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Move</button>
|
||||||
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Customer</button>
|
<button type="button" id="customer" value="SAL-000000000001" class="btn btn-primary btn-lg btn-block">Customer</button>
|
||||||
<button type="button" id="request_bills" class="btn btn-primary btn-lg btn-block">Req.Bill</button>
|
<button type="button" id="request_bills" class="btn btn-primary btn-lg btn-block">Req.Bill</button>
|
||||||
<!-- Cashier Buttons -->
|
<!-- Cashier Buttons -->
|
||||||
<button type="button" id="discount" class="btn btn-primary btn-lg btn-block">Discount</button>
|
<button type="button" id="discount" class="btn btn-primary btn-lg btn-block">Discount</button>
|
||||||
@@ -223,3 +222,146 @@
|
|||||||
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Re.Print</button>
|
<button type="button" class="btn btn-primary btn-lg btn-block" disabled>Re.Print</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
var old_order_id = 0
|
||||||
|
var old_table_name = ""
|
||||||
|
var table_or_order_id = 0
|
||||||
|
var pay_sale_id = 0
|
||||||
|
|
||||||
|
function callOrderDetails(sale_order_id){
|
||||||
|
|
||||||
|
var order_id = 0
|
||||||
|
var sale_id = 0
|
||||||
|
var data_val = ""
|
||||||
|
sale_order = sale_order_id.split("_")[0]
|
||||||
|
|
||||||
|
if (sale_order == 'sale') {
|
||||||
|
order_id = sale_order_id.split("_")[1]
|
||||||
|
url = "origami/"+sale_order_id.split("_")[1]
|
||||||
|
data_val = { sale_id: sale_order_id.split("_")[1]}
|
||||||
|
$("#pay").prop('disabled',false);
|
||||||
|
$("#customer").prop('disabled',false);
|
||||||
|
$("#request_bills").prop('disabled',true);
|
||||||
|
}else{
|
||||||
|
order_id = sale_order_id.split("_")[1]
|
||||||
|
url = "origami/"+order_id
|
||||||
|
data_val = { order_id: sale_order_id.split("_")[1]}
|
||||||
|
$("#request_bills").prop('disabled',false);
|
||||||
|
$("#pay").prop('disabled',true);
|
||||||
|
$("#customer").prop('disabled',true);
|
||||||
|
}
|
||||||
|
|
||||||
|
table_or_order_id = order_id
|
||||||
|
pay_sale_id = sale_id
|
||||||
|
alert(table_or_order_id)
|
||||||
|
var tbody = ""
|
||||||
|
$("#append-table").html("")
|
||||||
|
if (old_order_id != order_id){
|
||||||
|
$("#table-order-"+old_order_id).removeClass("selected_color")
|
||||||
|
$("#table-order-"+order_id).addClass("selected_color")
|
||||||
|
old_order_id = order_id
|
||||||
|
}
|
||||||
|
|
||||||
|
$("#order-detail-header").html("")
|
||||||
|
$("#order-detail-header").append("Table Name : "+document.getElementById("table-name-"+order_id).innerHTML)
|
||||||
|
$("#sub-total").html("")
|
||||||
|
$.ajax({type: "GET",
|
||||||
|
url: url,
|
||||||
|
data: data_val,
|
||||||
|
success:function(result){
|
||||||
|
var sub_total = 0
|
||||||
|
var discount_amount = 0
|
||||||
|
var receipt_no = ""
|
||||||
|
var cashier_name = ""
|
||||||
|
var receipt_date = ""
|
||||||
|
var tax_amount = 0
|
||||||
|
var grand_total_amount = 0
|
||||||
|
row = "<tbody>"
|
||||||
|
for (i = 0; i < result.length; i++) {
|
||||||
|
var data = JSON.stringify(result[i]);
|
||||||
|
var parse_data = JSON.parse(data)
|
||||||
|
sub_total += (parse_data.qty*parse_data.price)
|
||||||
|
row = '<tr><td style="width:60%; text-align:left"><span id="item-name-price">'+parse_data.item_name+"@"+(parse_data.price*1)+'</span></td>'
|
||||||
|
+'<td style="width:20%; text-align:right"><span id="item-qty">'+(parse_data.qty*1)+'</span></td>s'
|
||||||
|
+'<td style="width:20%; text-align:right"><span id="item-total-price">'+(parse_data.qty*parse_data.price)+'</span></td>'
|
||||||
|
+'</tr>>'
|
||||||
|
tbody += row
|
||||||
|
|
||||||
|
discount_amount = result[i].discount_amount;
|
||||||
|
|
||||||
|
tax_amount = result[i].tax_amount;
|
||||||
|
grand_total_amount = result[i].grand_total_amount;
|
||||||
|
|
||||||
|
receipt_no = result[i].receipt_no;
|
||||||
|
cashier_name = result[i].cashier_name;
|
||||||
|
receipt_date = result[i].receipt_date;
|
||||||
|
}
|
||||||
|
row = "</tbody>"
|
||||||
|
$("#append-table").append(tbody)
|
||||||
|
|
||||||
|
$("#sub-total").append((sub_total)+"<br/>")
|
||||||
|
|
||||||
|
if (discount_amount > 0 ) {
|
||||||
|
$("#discount-header").html("(Discount)")
|
||||||
|
$("#discount_amount").html("("+discount_amount+")")
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tax_amount > 0 ) {
|
||||||
|
$("#tax-header").html("Tax")
|
||||||
|
$("#tax_amount").html(tax_amount)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (grand_total_amount > 0 ) {
|
||||||
|
$("#grand-total-header").html("Grand Total")
|
||||||
|
$("#grand_total_amount").html(grand_total_amount)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cashier_name == null){
|
||||||
|
cashier_name = ""
|
||||||
|
}
|
||||||
|
if(receipt_no != null){
|
||||||
|
$("#receipt-no").html("Receipt No : "+receipt_no)
|
||||||
|
}
|
||||||
|
if (receipt_date != null) {
|
||||||
|
$("#receipt-date").html("Receipt Date : "+receipt_date);
|
||||||
|
}
|
||||||
|
if (cashier_name != null) {
|
||||||
|
$("#cashier-name").html("Cashier Name : "+cashier_name);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
error:function(result){
|
||||||
|
// alert('error');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
$( document ).ready(function() {
|
||||||
|
$('#request_bills').click(function() {
|
||||||
|
window.location.href = '/origami/request_bills/'+ table_or_order_id
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
$('#pay').click(function() {
|
||||||
|
window.location.href = '/origami/sale/'+ pay_sale_id + "/payment"
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#customer').click(function() {
|
||||||
|
var sale_id = $(this).val();
|
||||||
|
window.location.href = '/crm/customers/'+ sale_id + "/assign_sale_id"
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</script>
|
||||||
|
<style type="text/css">
|
||||||
|
.selected_color{
|
||||||
|
color:white;
|
||||||
|
background-color: blue;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|||||||
@@ -95,12 +95,12 @@ Rails.application.routes.draw do
|
|||||||
#--------- Customer Relationship Management ------------#
|
#--------- Customer Relationship Management ------------#
|
||||||
namespace :crm do
|
namespace :crm do
|
||||||
root "home#index" #queue number
|
root "home#index" #queue number
|
||||||
#customers
|
get 'customers/:sale_id/assign_sale_id', to: "customers#get_sale_id", :as => "assign_sale"#get sale id with customer for crm
|
||||||
resources :customers
|
resources :customers
|
||||||
#membership
|
post "update_booking" , to: "bookings#update_booking", as: "update_booking"#assign and cancel
|
||||||
#bookings
|
post "update_sale" , to: "home#update_sale_by_customer"#update customer id in sale table
|
||||||
post "update_booking" , to: "bookings#update_booking", as: "update_booking"
|
get '/print/:id', to: "home#print_order"#print order for crm
|
||||||
#queue
|
|
||||||
end
|
end
|
||||||
|
|
||||||
#--------- Order Queue Station ------------#
|
#--------- Order Queue Station ------------#
|
||||||
|
|||||||
Reference in New Issue
Block a user