caboose-cms 0.7.85 → 0.8.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/assets/javascripts/caboose/{admin_edit_order.js → admin_edit_invoice.js} +332 -189
- data/app/assets/javascripts/caboose/cart.js +15 -15
- data/app/assets/javascripts/caboose/cart_old.js +2 -2
- data/app/assets/javascripts/caboose/checkout/authnet_payment_method_controller.js +120 -0
- data/app/assets/javascripts/caboose/checkout/billing_address_controller.js +85 -0
- data/app/assets/javascripts/caboose/checkout/cart_controller.js +257 -0
- data/app/assets/javascripts/caboose/checkout/checkout_controller.js +258 -0
- data/app/assets/javascripts/caboose/checkout/gift_cards_controller.js +57 -0
- data/app/assets/javascripts/caboose/checkout/shipping_address_controller.js +86 -0
- data/app/assets/javascripts/caboose/checkout/shipping_method_controller.js +121 -0
- data/app/assets/javascripts/caboose/checkout/stripe_payment_method_controller.js +155 -0
- data/app/assets/javascripts/caboose/checkout_login_register.js +2 -2
- data/app/assets/javascripts/caboose/checkout_module.js +8 -8
- data/app/assets/javascripts/caboose/checkout_old.js +151 -0
- data/app/assets/javascripts/caboose/{checkout_payment.js → checkout_payment_authnet.js} +1 -1
- data/app/assets/javascripts/caboose/checkout_payment_stripe.js +212 -0
- data/app/assets/javascripts/caboose/checkout_shipping.js +1 -1
- data/app/assets/javascripts/caboose/jquery.payment.js +1 -0
- data/app/assets/javascripts/caboose/model/attribute.js +3 -2
- data/app/assets/javascripts/caboose/model/bound_control.js +56 -14
- data/app/assets/javascripts/caboose/model/bound_select.js +9 -11
- data/app/assets/javascripts/caboose/model/bound_select_simple.js +215 -0
- data/app/assets/javascripts/caboose/model/bound_text.js +7 -8
- data/app/assets/javascripts/caboose/{my_account_edit_order.js → my_account_edit_invoice.js} +55 -55
- data/app/assets/javascripts/caboose/united_states.js +65 -0
- data/app/assets/stylesheets/caboose/{my_account_edit_order.css.scss → my_account_edit_invoice.css.scss} +1 -1
- data/app/assets/templates/caboose/cart/line_items.jst.ejs +3 -3
- data/app/assets/templates/caboose/checkout/line_items.jst.ejs +7 -7
- data/app/controllers/caboose/ab_options_controller.rb +4 -4
- data/app/controllers/caboose/ab_variants_controller.rb +5 -5
- data/app/controllers/caboose/admin_controller.rb +0 -6
- data/app/controllers/caboose/application_controller.rb +16 -15
- data/app/controllers/caboose/billing_addresses_controller.rb +22 -22
- data/app/controllers/caboose/block_type_sources_controller.rb +8 -8
- data/app/controllers/caboose/block_types_controller.rb +2 -42
- data/app/controllers/caboose/blocks_controller.rb +26 -26
- data/app/controllers/caboose/calendars_controller.rb +5 -5
- data/app/controllers/caboose/cart_controller.rb +55 -36
- data/app/controllers/caboose/categories_controller.rb +78 -76
- data/app/controllers/caboose/checkout_controller.rb +313 -340
- data/app/controllers/caboose/checkout_controller_bak.rb +620 -0
- data/app/controllers/caboose/domains_controller.rb +5 -5
- data/app/controllers/caboose/event_groups_controller.rb +26 -4
- data/app/controllers/caboose/events_controller.rb +7 -6
- data/app/controllers/caboose/fonts_controller.rb +2 -2
- data/app/controllers/caboose/gift_cards_controller.rb +113 -139
- data/app/controllers/caboose/google_spreadsheets_controller.rb +1 -1
- data/app/controllers/caboose/{order_packages_controller.rb → invoice_packages_controller.rb} +49 -49
- data/app/controllers/caboose/{order_reports_controller.rb → invoice_reports_controller.rb} +11 -13
- data/app/controllers/caboose/invoice_transactions_controller.rb +35 -0
- data/app/controllers/caboose/invoices_controller.rb +328 -0
- data/app/controllers/caboose/line_items_controller.rb +35 -34
- data/app/controllers/caboose/login_controller.rb +7 -7
- data/app/controllers/caboose/login_logs_controller.rb +4 -4
- data/app/controllers/caboose/logout_controller.rb +3 -1
- data/app/controllers/caboose/media_categories_controller.rb +9 -9
- data/app/controllers/caboose/media_controller.rb +21 -46
- data/app/controllers/caboose/modal_controller.rb +4 -3
- data/app/controllers/caboose/modification_values_controller.rb +6 -6
- data/app/controllers/caboose/modifications_controller.rb +7 -6
- data/app/controllers/caboose/my_account_controller.rb +2 -2
- data/app/controllers/caboose/my_account_invoices_controller.rb +166 -0
- data/app/controllers/caboose/my_account_line_items_controller.rb +15 -13
- data/app/controllers/caboose/page_custom_fields_controller.rb +9 -8
- data/app/controllers/caboose/page_permissions_controller.rb +3 -3
- data/app/controllers/caboose/pages_controller.rb +132 -135
- data/app/controllers/caboose/permissions_controller.rb +8 -7
- data/app/controllers/caboose/post_categories_controller.rb +22 -7
- data/app/controllers/caboose/post_custom_fields_controller.rb +9 -8
- data/app/controllers/caboose/posts_controller.rb +35 -43
- data/app/controllers/caboose/product_images_controller.rb +5 -5
- data/app/controllers/caboose/products_controller.rb +53 -47
- data/app/controllers/caboose/redirects_controller.rb +7 -7
- data/app/controllers/caboose/register_controller.rb +2 -2
- data/app/controllers/caboose/retargeting_controller.rb +2 -61
- data/app/controllers/caboose/reviews_controller.rb +1 -0
- data/app/controllers/caboose/roles_controller.rb +10 -9
- data/app/controllers/caboose/settings_controller.rb +9 -7
- data/app/controllers/caboose/shipping_addresses_controller.rb +18 -18
- data/app/controllers/caboose/shipping_packages_controller.rb +24 -21
- data/app/controllers/caboose/sites_controller.rb +35 -25
- data/app/controllers/caboose/smtp_controller.rb +3 -3
- data/app/controllers/caboose/sns_controller.rb +6 -6
- data/app/controllers/caboose/social_controller.rb +5 -6
- data/app/controllers/caboose/stackable_groups_controller.rb +10 -8
- data/app/controllers/caboose/station_controller.rb +3 -3
- data/app/controllers/caboose/store_controller.rb +93 -87
- data/app/controllers/caboose/subscriptions_controller.rb +153 -0
- data/app/controllers/caboose/users_controller.rb +25 -22
- data/app/controllers/caboose/variants_controller.rb +72 -93
- data/app/controllers/caboose/vendors_controller.rb +35 -32
- data/app/mailers/caboose/{orders_mailer.rb → invoices_mailer.rb} +21 -21
- data/app/mailers/caboose/login_mailer.rb +3 -3
- data/app/models/caboose/authnet.rb +295 -195
- data/app/models/caboose/comment_routes.rb +68 -41
- data/app/models/caboose/core_plugin.rb +1 -1
- data/app/models/caboose/discount.rb +14 -3
- data/app/models/caboose/domain_constraint.rb +11 -3
- data/app/models/caboose/gift_card.rb +8 -8
- data/app/models/caboose/invoice.rb +706 -0
- data/app/models/caboose/invoice_discount.rb +10 -0
- data/app/models/caboose/invoice_package.rb +76 -0
- data/app/models/caboose/{order_package_calculator.rb → invoice_package_calculator.rb} +20 -20
- data/app/models/caboose/{order_pdf.rb → invoice_pdf.rb} +30 -30
- data/app/models/caboose/{order_reporter.rb → invoice_reporter.rb} +5 -5
- data/app/models/caboose/invoice_transaction.rb +169 -0
- data/app/models/caboose/line_item.rb +11 -8
- data/app/models/caboose/payment_processors/authorizenet.rb +15 -15
- data/app/models/caboose/payment_processors/base.rb +3 -3
- data/app/models/caboose/{pending_orders_pdf.rb → pending_invoices_pdf.rb} +31 -31
- data/app/models/caboose/product.rb +2 -4
- data/app/models/caboose/schema.rb +159 -111
- data/app/models/caboose/shipping_calculator.rb +41 -139
- data/app/models/caboose/smtp_config.rb +2 -1
- data/app/models/caboose/store_config.rb +7 -7
- data/app/models/caboose/subscription.rb +32 -0
- data/app/models/caboose/tax_calculator.rb +36 -36
- data/app/models/caboose/user.rb +6 -0
- data/app/models/caboose/user_subscription.rb +142 -0
- data/app/models/caboose/wish_list.rb +14 -0
- data/app/models/caboose/wish_list_line_item.rb +13 -0
- data/app/views/caboose/blocks/_products.html.erb +10 -13
- data/app/views/caboose/checkout/_address_form.html.erb +14 -14
- data/app/views/caboose/checkout/_billing_form.html.erb +3 -3
- data/app/views/caboose/checkout/_cart.html.erb +7 -7
- data/app/views/caboose/checkout/_cart_old.html.erb +9 -9
- data/app/views/caboose/checkout/_confirm.html.erb +9 -9
- data/app/views/caboose/checkout/_order_discount.html.erb +3 -3
- data/app/views/caboose/checkout/_shipping_address.html.erb +1 -1
- data/app/views/caboose/checkout/_shipping_method.html.erb +1 -1
- data/app/views/caboose/checkout/addresses.html.erb +10 -10
- data/app/views/caboose/checkout/authnet.html.erb +34 -0
- data/app/views/caboose/checkout/authnet_response_handler.html.erb +3 -0
- data/app/views/caboose/checkout/checkout.html.erb +100 -0
- data/app/views/caboose/checkout/confirm_without_payment.html.erb +6 -6
- data/app/views/caboose/checkout/discount.html.erb +1 -1
- data/app/views/caboose/checkout/index.html.erb +4 -4
- data/app/views/caboose/checkout/payment_authnet.html.erb +140 -0
- data/app/views/caboose/checkout/payment_stripe.html.erb +95 -0
- data/app/views/caboose/checkout/shipping.html.erb +4 -4
- data/app/views/caboose/checkout/thanks.html.erb +3 -3
- data/app/views/caboose/gift_cards/admin_edit.html.erb +19 -19
- data/app/views/caboose/gift_cards/admin_index.html.erb +9 -9
- data/app/views/caboose/{orders → invoices}/_admin_footer.html.erb +0 -0
- data/app/views/caboose/{orders → invoices}/_admin_header.html.erb +0 -0
- data/app/views/caboose/{orders/_quickbooks_order.html.erb → invoices/_quickbooks_invoice.html.erb} +0 -0
- data/app/views/caboose/{orders → invoices}/admin_city_report.html.erb +1 -1
- data/app/views/caboose/invoices/admin_delete_form.html.erb +18 -0
- data/app/views/caboose/{orders → invoices}/admin_edit.html.erb +14 -14
- data/app/views/caboose/{orders → invoices}/admin_index.html.erb +24 -24
- data/app/views/caboose/{orders → invoices}/admin_invalid_order.html.erb +2 -2
- data/app/views/caboose/{orders → invoices}/admin_new.html.erb +7 -7
- data/app/views/caboose/{orders → invoices}/admin_print.html.erb +15 -15
- data/app/views/caboose/{orders → invoices}/admin_summary_report.html.erb +4 -4
- data/app/views/caboose/{orders_mailer/customer_new_order.html.erb → invoices_mailer/customer_new_invoice.html.erb} +21 -21
- data/app/views/caboose/invoices_mailer/customer_payment_authorization.html.erb +5 -0
- data/app/views/caboose/{orders_mailer → invoices_mailer}/customer_status_updated.html.erb +22 -22
- data/app/views/caboose/{orders_mailer/fulfillment_new_order.html.erb → invoices_mailer/fulfillment_new_invoice.html.erb} +23 -23
- data/app/views/caboose/{orders_mailer/shipping_order_ready.html.erb → invoices_mailer/shipping_invoice_ready.html.erb} +0 -0
- data/app/views/caboose/{orders_mailer → invoices_mailer}/test_email.html.erb +0 -0
- data/app/views/caboose/line_items/admin_new.html.erb +1 -1
- data/app/views/caboose/login_mailer/forgot_password_email.html.erb +2 -3
- data/app/views/caboose/my_account/index.html.erb +1 -1
- data/app/views/caboose/{my_account_orders → my_account_invoices}/authnet_relay.html.erb +0 -0
- data/app/views/caboose/{my_account_orders → my_account_invoices}/authnet_response.html.erb +0 -0
- data/app/views/caboose/{my_account_orders → my_account_invoices}/edit.html.erb +9 -9
- data/app/views/caboose/my_account_invoices/index.html.erb +36 -0
- data/app/views/caboose/{my_account_orders → my_account_invoices}/payment_form.html.erb +10 -10
- data/app/views/caboose/post_categories/admin_index.html.erb +1 -1
- data/app/views/caboose/sites/admin_edit.html.erb +1 -1
- data/app/views/caboose/store/admin_edit_general.html.erb +5 -3
- data/app/views/caboose/store/admin_edit_packages.html.erb +6 -6
- data/app/views/caboose/store/admin_edit_shipping.html.erb +3 -3
- data/app/views/caboose/store/admin_edit_tax.html.erb +1 -1
- data/app/views/caboose/subscriptions/admin_edit.html.erb +82 -0
- data/app/views/caboose/subscriptions/admin_index.html.erb +45 -0
- data/config/routes.rb +1 -759
- data/config/routes_old.rb +759 -0
- data/lib/caboose/version.rb +1 -1
- data/lib/tasks/caboose.rake +41 -15
- metadata +101 -61
- data/app/controllers/caboose/my_account_orders_controller.rb +0 -165
- data/app/controllers/caboose/orders_controller.rb +0 -310
- data/app/models/caboose/order.rb +0 -479
- data/app/models/caboose/order_discount.rb +0 -10
- data/app/models/caboose/order_package.rb +0 -133
- data/app/models/caboose/order_transaction.rb +0 -41
- data/app/models/caboose/payment_processors/payscape.rb +0 -94
- data/app/views/caboose/checkout/payment.html.erb +0 -146
- data/app/views/caboose/my_account_orders/index.html.erb +0 -36
- data/app/views/caboose/orders/admin_delete_form.html.erb +0 -21
- data/app/views/caboose/orders_mailer/customer_payment_authorization.html.erb +0 -5
@@ -3,7 +3,7 @@ require 'httparty'
|
|
3
3
|
module Caboose
|
4
4
|
class GoogleSpreadsheetsController < Caboose::ApplicationController
|
5
5
|
|
6
|
-
# GET /google-spreadsheets/:spreadsheet_id/csv
|
6
|
+
# @route GET /google-spreadsheets/:spreadsheet_id/csv
|
7
7
|
def csv_data
|
8
8
|
spreadsheet_id = params[:spreadsheet_id]
|
9
9
|
#url = "https://docs.google.com/spreadsheets/d/#{spreadsheet_id}/export?format=csv&id=#{spreadsheet_id}&gid=0"
|
data/app/controllers/caboose/{order_packages_controller.rb → invoice_packages_controller.rb}
RENAMED
@@ -1,18 +1,18 @@
|
|
1
1
|
module Caboose
|
2
|
-
class
|
2
|
+
class InvoicePackagesController < Caboose::ApplicationController
|
3
3
|
|
4
|
-
# GET /admin/
|
4
|
+
# @route GET /admin/invoices/:invoice_id/packages/json
|
5
5
|
def admin_json
|
6
|
-
return if !user_is_allowed('
|
7
|
-
|
8
|
-
render :json =>
|
6
|
+
return if !user_is_allowed('invoices', 'view')
|
7
|
+
invoice = Invoice.find(params[:invoice_id])
|
8
|
+
render :json => invoice.invoice_packages.as_json(
|
9
9
|
:include => { :shipping_package => { :include => :shipping_methods} }
|
10
10
|
)
|
11
11
|
end
|
12
12
|
|
13
|
-
# POST /admin/
|
13
|
+
# @route POST /admin/invoices/:invoice_id/packages
|
14
14
|
def admin_add
|
15
|
-
return if !user_is_allowed('
|
15
|
+
return if !user_is_allowed('invoices', 'add')
|
16
16
|
|
17
17
|
resp = StdClass.new
|
18
18
|
|
@@ -20,32 +20,32 @@ module Caboose
|
|
20
20
|
elsif params[:shipping_method_id].strip.length == 0 then resp.error = "Please select a shipping method."
|
21
21
|
else
|
22
22
|
|
23
|
-
op =
|
24
|
-
:
|
23
|
+
op = InvoicePackage.new(
|
24
|
+
:invoice_id => params[:invoice_id],
|
25
25
|
:shipping_package_id => params[:shipping_package_id],
|
26
26
|
:shipping_method_id => params[:shipping_method_id],
|
27
|
-
:status =>
|
27
|
+
:status => InvoicePackage::STATUS_PENDING
|
28
28
|
)
|
29
29
|
op.save
|
30
30
|
resp.new_id = op.id
|
31
|
-
resp.redirect = "/admin/
|
31
|
+
resp.redirect = "/admin/invoices/#{params[:invoice_id]}/packages/#{op.id}"
|
32
32
|
|
33
33
|
end
|
34
34
|
|
35
35
|
render :json => resp
|
36
36
|
end
|
37
37
|
|
38
|
-
# PUT /admin/
|
38
|
+
# @route PUT /admin/invoices/:invoice_id/packages/:id
|
39
39
|
def admin_update
|
40
|
-
return if !user_is_allowed('
|
40
|
+
return if !user_is_allowed('invoices', 'edit')
|
41
41
|
|
42
42
|
resp = Caboose::StdClass.new
|
43
|
-
op =
|
43
|
+
op = InvoicePackage.find(params[:id])
|
44
44
|
|
45
45
|
save = true
|
46
46
|
params.each do |name,value|
|
47
47
|
case name
|
48
|
-
when '
|
48
|
+
when 'invoice_id' then op.invoice_id = value
|
49
49
|
when 'shipping_method_id' then op.shipping_method_id = value
|
50
50
|
when 'shipping_package_id' then op.shipping_package_id = value
|
51
51
|
when 'status' then op.status = value
|
@@ -59,17 +59,17 @@ module Caboose
|
|
59
59
|
end
|
60
60
|
|
61
61
|
op.save
|
62
|
-
op.
|
63
|
-
op.
|
64
|
-
op.
|
62
|
+
op.invoice.shipping = op.invoice.calculate_shipping
|
63
|
+
op.invoice.total = op.invoice.calculate_total
|
64
|
+
op.invoice.save
|
65
65
|
|
66
66
|
resp.success = true
|
67
67
|
render :json => resp
|
68
68
|
end
|
69
69
|
|
70
|
-
# PUT /admin/
|
70
|
+
# @route PUT /admin/invoices/:invoice_id/line-items/:id
|
71
71
|
def admin_update_line_item
|
72
|
-
return if !user_is_allowed('
|
72
|
+
return if !user_is_allowed('invoices', 'edit')
|
73
73
|
|
74
74
|
resp = Caboose::StdClass.new({'attributes' => {}})
|
75
75
|
li = LineItem.find(params[:id])
|
@@ -83,12 +83,12 @@ module Caboose
|
|
83
83
|
li.save
|
84
84
|
|
85
85
|
# Recalculate everything
|
86
|
-
r = ShippingCalculator.rate(li.
|
87
|
-
li.
|
88
|
-
li.
|
89
|
-
li.
|
90
|
-
li.
|
91
|
-
li.
|
86
|
+
r = ShippingCalculator.rate(li.invoice, li.invoice.shipping_method_code)
|
87
|
+
li.invoice.shipping = r['negotiated_rate'] / 100
|
88
|
+
li.invoice.handling = (r['negotiated_rate'] / 100) * 0.05
|
89
|
+
li.invoice.tax = TaxCalculator.tax(li.invoice)
|
90
|
+
li.invoice.calculate_total
|
91
|
+
li.invoice.save
|
92
92
|
|
93
93
|
when 'tracking_number'
|
94
94
|
li.tracking_number = value
|
@@ -100,36 +100,36 @@ module Caboose
|
|
100
100
|
end
|
101
101
|
end
|
102
102
|
if send_status_email
|
103
|
-
|
103
|
+
InvoicesMailer.configure_for_site(@site.id).customer_status_updated(li.invoice).deliver
|
104
104
|
end
|
105
105
|
resp.success = save && li.save
|
106
106
|
render :json => resp
|
107
107
|
end
|
108
108
|
|
109
|
-
# DELETE /admin/
|
109
|
+
# @route DELETE /admin/invoices/:invoice_id/packages/:id
|
110
110
|
def admin_delete
|
111
|
-
return if !user_is_allowed('
|
111
|
+
return if !user_is_allowed('invoices', 'delete')
|
112
112
|
resp = StdClass.new
|
113
|
-
op =
|
113
|
+
op = InvoicePackage.find(params[:id])
|
114
114
|
if op.line_items.nil? || op.line_items.count == 0
|
115
115
|
op.destroy
|
116
|
-
resp.redirect = "/admin/
|
116
|
+
resp.redirect = "/admin/invoices/#{params[:invoice_id]}"
|
117
117
|
else
|
118
118
|
resp.error = "Only empty packages can be deleted."
|
119
119
|
end
|
120
120
|
render :json => resp
|
121
121
|
end
|
122
122
|
|
123
|
-
# GET /admin/
|
123
|
+
# @route GET /admin/invoices/:invoice_id/packages/:id/calculate-shipping
|
124
124
|
def calculate_shipping
|
125
|
-
return if !user_is_allowed('
|
125
|
+
return if !user_is_allowed('invoices', 'edit')
|
126
126
|
|
127
|
-
op =
|
128
|
-
|
127
|
+
op = InvoicePackage.find(params[:id])
|
128
|
+
invoice = op.invoice
|
129
129
|
|
130
|
-
render :json => { :error => "Empty
|
131
|
-
render :json => { :error => "No shippable items in
|
132
|
-
render :json => { :error => "Empty shipping address" } and return if
|
130
|
+
render :json => { :error => "Empty invoice" } and return if invoice.nil?
|
131
|
+
render :json => { :error => "No shippable items in invoice package" } and return if !invoice.has_shippable_items?
|
132
|
+
render :json => { :error => "Empty shipping address" } and return if invoice.shipping_address.nil?
|
133
133
|
|
134
134
|
rate = ShippingCalculator.calculate_rate(op)
|
135
135
|
render :json => { :error => "No rate found for given shipping package and method" } and return if rate.nil?
|
@@ -137,26 +137,26 @@ module Caboose
|
|
137
137
|
op.total = rate
|
138
138
|
op.save
|
139
139
|
|
140
|
-
|
141
|
-
|
142
|
-
|
140
|
+
invoice.calculate_shipping
|
141
|
+
invoice.calculate_total
|
142
|
+
invoice.save
|
143
143
|
|
144
144
|
render :json => { :error => "No rate found for shipping method" } and return if rate.nil?
|
145
145
|
render :json => { :success => true, :rate => rate }
|
146
146
|
end
|
147
147
|
|
148
|
-
# GET /admin/
|
148
|
+
# @route GET /admin/invoices/:invoice_id/packages/:id/shipping-rates
|
149
149
|
def shipping_rates
|
150
|
-
return if !user_is_allowed('
|
150
|
+
return if !user_is_allowed('invoices', 'edit')
|
151
151
|
|
152
|
-
op =
|
153
|
-
|
152
|
+
op = InvoicePackage.find(params[:id])
|
153
|
+
invoice = op.invoice
|
154
154
|
|
155
|
-
render :json => { :error => "Empty
|
156
|
-
render :json => { :error => "No shippable items in
|
157
|
-
render :json => { :error => "Empty shipping address" } and return if
|
155
|
+
render :json => { :error => "Empty invoice" } and return if invoice.nil?
|
156
|
+
render :json => { :error => "No shippable items in invoice package" } and return if !invoice.has_shippable_items?
|
157
|
+
render :json => { :error => "Empty shipping address" } and return if invoice.shipping_address.nil?
|
158
158
|
|
159
|
-
rates = ShippingCalculator.
|
159
|
+
rates = ShippingCalculator.invoice_package_rates(op)
|
160
160
|
render :json => rates
|
161
161
|
end
|
162
162
|
|
@@ -1,21 +1,21 @@
|
|
1
1
|
module Caboose
|
2
|
-
class
|
2
|
+
class InvoicesController < Caboose::ApplicationController
|
3
3
|
|
4
|
-
# GET /admin/
|
4
|
+
# GET /admin/invoices/summary-report
|
5
5
|
def admin_summary_report
|
6
|
-
return if !user_is_allowed('
|
6
|
+
return if !user_is_allowed('invoices', 'view')
|
7
7
|
|
8
8
|
q = ["select
|
9
9
|
concat(date_part('year', date_authorized), '-', date_part('month', date_authorized), '-', date_part('day', date_authorized)),
|
10
10
|
count(*),
|
11
11
|
sum(total)
|
12
|
-
from
|
12
|
+
from store_invoices
|
13
13
|
where site_id = ?
|
14
14
|
and (financial_status = ? or financial_status = ?)
|
15
15
|
and date_authorized >= ?
|
16
16
|
and date_authorized < ?
|
17
17
|
group by concat(date_part('year', date_authorized), '-', date_part('month', date_authorized), '-', date_part('day', date_authorized))
|
18
|
-
|
18
|
+
invoice by concat(date_part('year', date_authorized), '-', date_part('month', date_authorized), '-', date_part('day', date_authorized))",
|
19
19
|
@site.id, 'authorized', 'captured', @d1, @d2]
|
20
20
|
rows = ActiveRecord::Base.connection.select_rows(ActiveRecord::Base.send(:sanitize_sql_array, q))
|
21
21
|
return rows.collect { |row|
|
@@ -34,30 +34,28 @@ module Caboose
|
|
34
34
|
@pager = Caboose::PageBarGenerator.new(params, {
|
35
35
|
'site_id' => @site.id,
|
36
36
|
'customer_id' => '',
|
37
|
-
'status' =>
|
37
|
+
'status' => Invoice::STATUS_PENDING,
|
38
38
|
'shipping_method_code' => '',
|
39
39
|
'id' => ''
|
40
40
|
}, {
|
41
|
-
'model' => 'Caboose::
|
41
|
+
'model' => 'Caboose::Invoice',
|
42
42
|
'sort' => 'id',
|
43
43
|
'desc' => 1,
|
44
|
-
'base_url' => '/admin/
|
44
|
+
'base_url' => '/admin/invoices',
|
45
45
|
'use_url_params' => false
|
46
46
|
})
|
47
47
|
|
48
|
-
@
|
48
|
+
@invoices = @pager.items
|
49
49
|
@customers = Caboose::User.reorder('last_name, first_name').all
|
50
50
|
|
51
51
|
render :layout => 'caboose/admin'
|
52
52
|
end
|
53
53
|
|
54
|
-
# GET /admin/
|
54
|
+
# GET /admin/invoices/new
|
55
55
|
def admin_new
|
56
|
-
return if !user_is_allowed('
|
56
|
+
return if !user_is_allowed('invoices', 'add')
|
57
57
|
render :layout => 'caboose/admin'
|
58
58
|
end
|
59
59
|
|
60
|
-
|
61
|
-
|
62
60
|
end
|
63
61
|
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
module Caboose
|
2
|
+
class InvoiceTransactionsController < Caboose::ApplicationController
|
3
|
+
|
4
|
+
# @route GET /admin/invoices/:invoice_id/transactions/:id/capture
|
5
|
+
def admin_capture
|
6
|
+
return if !user_is_allowed('invoices', 'edit')
|
7
|
+
|
8
|
+
it = InvoiceTransaction.find(params[:id])
|
9
|
+
resp = it.capture
|
10
|
+
|
11
|
+
render :json => resp
|
12
|
+
end
|
13
|
+
|
14
|
+
# @route GET /admin/invoices/:invoice_id/transactions/:id/refund
|
15
|
+
def admin_refund
|
16
|
+
return if !user_is_allowed('invoices', 'edit')
|
17
|
+
|
18
|
+
it = InvoiceTransaction.find(params[:id])
|
19
|
+
resp = it.refund
|
20
|
+
|
21
|
+
render :json => resp
|
22
|
+
end
|
23
|
+
|
24
|
+
# @route GET /admin/invoices/:invoice_id/transactions/:id/void
|
25
|
+
def admin_void
|
26
|
+
return if !user_is_allowed('invoices', 'edit')
|
27
|
+
|
28
|
+
it = InvoiceTransaction.find(params[:id])
|
29
|
+
resp = it.void
|
30
|
+
|
31
|
+
render :json => resp
|
32
|
+
end
|
33
|
+
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,328 @@
|
|
1
|
+
module Caboose
|
2
|
+
class InvoicesController < Caboose::ApplicationController
|
3
|
+
|
4
|
+
# @route GET /admin/invoices/weird-test
|
5
|
+
def admin_weird_test
|
6
|
+
Caboose.log("Before the admin_weird_test")
|
7
|
+
x = Invoice.new
|
8
|
+
Caboose.log("After the admin_weird_test")
|
9
|
+
render :json => x
|
10
|
+
end
|
11
|
+
|
12
|
+
# @route GET /admin/invoices
|
13
|
+
def admin_index
|
14
|
+
return if !user_is_allowed('invoices', 'view')
|
15
|
+
|
16
|
+
@pager = Caboose::PageBarGenerator.new(params, {
|
17
|
+
'site_id' => @site.id,
|
18
|
+
'customer_id' => '',
|
19
|
+
'status' => Invoice::STATUS_PENDING,
|
20
|
+
'shipping_method_code' => '',
|
21
|
+
'id' => '',
|
22
|
+
'invoice_number' => ''
|
23
|
+
}, {
|
24
|
+
'model' => 'Caboose::Invoice',
|
25
|
+
'sort' => 'id',
|
26
|
+
'desc' => 1,
|
27
|
+
'base_url' => '/admin/invoices',
|
28
|
+
'use_url_params' => false,
|
29
|
+
'items_per_page' => 100
|
30
|
+
})
|
31
|
+
|
32
|
+
@invoices = @pager.items
|
33
|
+
@customers = Caboose::User.where(:site_id => @site.id).reorder('last_name, first_name').all
|
34
|
+
|
35
|
+
render :layout => 'caboose/admin'
|
36
|
+
end
|
37
|
+
|
38
|
+
# @route GET /admin/invoices/:id/refresh-transactions
|
39
|
+
def refresh_transactions
|
40
|
+
return if !user_is_allowed('invoices', 'add')
|
41
|
+
|
42
|
+
resp = Caboose::StdClass.new
|
43
|
+
|
44
|
+
invoice = Invoice.find(params[:id])
|
45
|
+
invoice.refresh_transactions
|
46
|
+
resp.financial_status = invoice.financial_status
|
47
|
+
resp.invoice_transactions = invoice.invoice_transactions.reorder(:date_processed).all
|
48
|
+
|
49
|
+
render :json => resp
|
50
|
+
end
|
51
|
+
|
52
|
+
# @route GET /admin/invoices/new
|
53
|
+
def admin_new
|
54
|
+
return if !user_is_allowed('invoices', 'add')
|
55
|
+
render :layout => 'caboose/admin'
|
56
|
+
end
|
57
|
+
|
58
|
+
# @route POST /admin/invoices
|
59
|
+
def admin_add
|
60
|
+
return if !user_is_allowed('invoices', 'add')
|
61
|
+
invoice = Invoice.create(
|
62
|
+
:site_id => @site.id,
|
63
|
+
:status => Invoice::STATUS_PENDING,
|
64
|
+
:financial_status => Invoice::FINANCIAL_STATUS_PENDING,
|
65
|
+
:invoice_number => @site.store_config.next_invoice_number
|
66
|
+
)
|
67
|
+
render :json => { :sucess => true, :redirect => "/admin/invoices/#{invoice.id}" }
|
68
|
+
end
|
69
|
+
|
70
|
+
# @route_priority 50
|
71
|
+
# @route GET /admin/invoices/:id
|
72
|
+
def admin_edit
|
73
|
+
return if !user_is_allowed('invoices', 'edit')
|
74
|
+
@invoice = Invoice.where(:id => params[:id]).first
|
75
|
+
|
76
|
+
if params[:id].nil? || @invoice.nil?
|
77
|
+
render :file => 'caboose/invoices/admin_invalid_invoice', :layout => 'caboose/admin'
|
78
|
+
return
|
79
|
+
end
|
80
|
+
render :layout => 'caboose/admin'
|
81
|
+
end
|
82
|
+
|
83
|
+
# @route GET /admin/invoices/:id/calculate-tax
|
84
|
+
def admin_calculate_tax
|
85
|
+
return if !user_is_allowed('invoices', 'edit')
|
86
|
+
invoice = Invoice.find(params[:id])
|
87
|
+
invoice.tax = invoice.calculate_tax
|
88
|
+
invoice.total = invoice.calculate_total
|
89
|
+
invoice.save
|
90
|
+
render :json => { :success => true }
|
91
|
+
end
|
92
|
+
|
93
|
+
# @route GET /admin/invoices/:id/calculate-handling
|
94
|
+
def admin_calculate_handling
|
95
|
+
return if !user_is_allowed('invoices', 'edit')
|
96
|
+
invoice = Invoice.find(params[:id])
|
97
|
+
invoice.handling = invoice.calculate_handling
|
98
|
+
invoice.total = invoice.calculate_total
|
99
|
+
invoice.save
|
100
|
+
render :json => { :success => true }
|
101
|
+
end
|
102
|
+
|
103
|
+
# @route GET /admin/invoices/:id/capture
|
104
|
+
def capture_funds
|
105
|
+
return if !user_is_allowed('invoices', 'edit')
|
106
|
+
|
107
|
+
invoice = Invoice.find(params[:id])
|
108
|
+
resp = invoice.capture_funds
|
109
|
+
|
110
|
+
# Tell taxcloud the invoice was captured
|
111
|
+
#Caboose::TaxCalculator.captured(invoice)
|
112
|
+
|
113
|
+
render :json => resp
|
114
|
+
end
|
115
|
+
|
116
|
+
# @route GET /admin/invoices/:id/void
|
117
|
+
def admin_void
|
118
|
+
return if !user_is_allowed('invoices', 'edit')
|
119
|
+
|
120
|
+
invoice = Invoice.find(params[:id])
|
121
|
+
resp = invoice.void
|
122
|
+
|
123
|
+
render :json => resp
|
124
|
+
end
|
125
|
+
|
126
|
+
# @route GET /admin/invoices/:id/refund
|
127
|
+
def admin_refund
|
128
|
+
return if !user_is_allowed('invoices', 'edit')
|
129
|
+
|
130
|
+
invoice = Invoice.find(params[:id])
|
131
|
+
resp = invoice.refund
|
132
|
+
|
133
|
+
render :json => resp
|
134
|
+
end
|
135
|
+
|
136
|
+
# @route POST /admin/invoices/:id/resend-confirmation
|
137
|
+
def admin_resend_confirmation
|
138
|
+
if Invoice.find(params[:id]).resend_confirmation
|
139
|
+
render :json => { success: "Confirmation re-sent successfully." }
|
140
|
+
else
|
141
|
+
render :json => { error: "There was an error re-sending the email." }
|
142
|
+
end
|
143
|
+
end
|
144
|
+
|
145
|
+
# @route GET /admin/invoices/:id/json
|
146
|
+
def admin_json
|
147
|
+
return if !user_is_allowed('invoices', 'edit')
|
148
|
+
invoice = Invoice.find(params[:id])
|
149
|
+
if invoice.shipping_address_id.nil?
|
150
|
+
sa = Address.create
|
151
|
+
invoice.shipping_address_id = sa.id
|
152
|
+
invoice.save
|
153
|
+
end
|
154
|
+
render :json => invoice.as_json(:include => [
|
155
|
+
{ :line_items => { :include => { :variant => { :include => :product }}}},
|
156
|
+
{ :invoice_packages => { :include => [:shipping_package, :shipping_method] }},
|
157
|
+
{ :discounts => { :include => :gift_card }},
|
158
|
+
:customer,
|
159
|
+
:shipping_address,
|
160
|
+
:billing_address,
|
161
|
+
:invoice_transactions
|
162
|
+
])
|
163
|
+
end
|
164
|
+
|
165
|
+
# @route GET /admin/invoices/:id/print
|
166
|
+
def admin_print
|
167
|
+
return if !user_is_allowed('invoices', 'edit')
|
168
|
+
|
169
|
+
pdf = InvoicePdf.new
|
170
|
+
pdf.invoice = Invoice.find(params[:id])
|
171
|
+
send_data pdf.to_pdf, :filename => "invoice_#{pdf.invoice.id}.pdf", :type => "application/pdf", :disposition => "inline"
|
172
|
+
end
|
173
|
+
|
174
|
+
# @route GET /admin/invoices/print-pending
|
175
|
+
def admin_print_pending
|
176
|
+
return if !user_is_allowed('invoices', 'edit')
|
177
|
+
|
178
|
+
pdf = PendingInvoicesPdf.new
|
179
|
+
if params[:print_card_details]
|
180
|
+
pdf.print_card_details = params[:print_card_details].to_i == 1
|
181
|
+
end
|
182
|
+
pdf.invoices = Invoice.where(:site_id => @site.id, :status => Invoice::STATUS_PENDING).all
|
183
|
+
send_data pdf.to_pdf, :filename => "pending_invoices.pdf", :type => "application/pdf", :disposition => "inline"
|
184
|
+
end
|
185
|
+
|
186
|
+
# @route PUT /admin/invoices/:id
|
187
|
+
def admin_update
|
188
|
+
return if !user_is_allowed('invoices', 'edit')
|
189
|
+
|
190
|
+
resp = Caboose::StdClass.new({'attributes' => {}})
|
191
|
+
invoice = Invoice.find(params[:id])
|
192
|
+
|
193
|
+
save = true
|
194
|
+
params.each do |name,value|
|
195
|
+
case name
|
196
|
+
when 'tax' then
|
197
|
+
invoice.tax = value
|
198
|
+
invoice.total = invoice.calculate_total
|
199
|
+
when 'handling' then
|
200
|
+
invoice.handling = value
|
201
|
+
invoice.total = invoice.calculate_total
|
202
|
+
when 'custom_discount' then
|
203
|
+
invoice.custom_discount = value
|
204
|
+
invoice.discount = invoice.calculate_discount
|
205
|
+
invoice.total = invoice.calculate_total
|
206
|
+
when 'status' then
|
207
|
+
invoice.status = value
|
208
|
+
if value == 'Shipped'
|
209
|
+
invoice.date_shipped = DateTime.now.utc
|
210
|
+
end
|
211
|
+
when 'customer_id' then invoice.customer_id = value
|
212
|
+
end
|
213
|
+
end
|
214
|
+
|
215
|
+
#invoice.calculate
|
216
|
+
#invoice.calculate_total
|
217
|
+
#resp.attributes['total'] = { 'value' => invoice.total }
|
218
|
+
|
219
|
+
resp.success = save && invoice.save
|
220
|
+
render :json => resp
|
221
|
+
end
|
222
|
+
|
223
|
+
# @route DELETE /admin/invoices/:id
|
224
|
+
def admin_delete
|
225
|
+
return if !user_is_allowed('invoices', 'delete')
|
226
|
+
Invoice.find(params[:id]).destroy
|
227
|
+
render :json => Caboose::StdClass.new({
|
228
|
+
:redirect => '/admin/invoices'
|
229
|
+
})
|
230
|
+
end
|
231
|
+
|
232
|
+
# @route GET /admin/invoices/:id/send-for-authorization
|
233
|
+
def admin_send_for_authorization
|
234
|
+
return if !user_is_allowed('invoices', 'edit')
|
235
|
+
invoice = Invoice.find(params[:id])
|
236
|
+
invoice.delay.send_payment_authorization_email
|
237
|
+
render :json => { :success => true }
|
238
|
+
end
|
239
|
+
|
240
|
+
# @route GET /admin/invoices/city-report
|
241
|
+
def admin_city_report
|
242
|
+
return if !user_is_allowed('invoices', 'view')
|
243
|
+
|
244
|
+
@d1 = params[:d1] ? DateTime.strptime("#{params[:d1]} 00:00:00", '%Y-%m-%d %H:%M:%S') : DateTime.strptime(DateTime.now.strftime("%Y-%m-01 00:00:00"), '%Y-%m-%d %H:%M:%S')
|
245
|
+
@d2 = params[:d2] ? DateTime.strptime("#{params[:d2]} 00:00:00", '%Y-%m-%d %H:%M:%S') : @d1 + 1.month
|
246
|
+
@rows = InvoiceReporter.city_report(@site.id, @d1, @d2)
|
247
|
+
|
248
|
+
render :layout => 'caboose/admin'
|
249
|
+
end
|
250
|
+
|
251
|
+
# @route GET /admin/invoices/summary-report
|
252
|
+
def admin_summary_report
|
253
|
+
return if !user_is_allowed('invoices', 'view')
|
254
|
+
|
255
|
+
@d1 = params[:d1] ? DateTime.strptime("#{params[:d1]} 00:00:00", '%Y-%m-%d %H:%M:%S') : DateTime.strptime(DateTime.now.strftime("%Y-%m-01 00:00:00"), '%Y-%m-%d %H:%M:%S')
|
256
|
+
@d2 = params[:d2] ? DateTime.strptime("#{params[:d2]} 00:00:00", '%Y-%m-%d %H:%M:%S') : @d1 + 1.month
|
257
|
+
@rows = InvoiceReporter.summary_report(@site.id, @d1, @d2)
|
258
|
+
|
259
|
+
render :layout => 'caboose/admin'
|
260
|
+
end
|
261
|
+
|
262
|
+
# @route GET /admin/invoices/:field-options
|
263
|
+
def admin_options
|
264
|
+
return if !user_is_allowed('invoices', 'view')
|
265
|
+
|
266
|
+
options = []
|
267
|
+
case params[:field]
|
268
|
+
when 'status'
|
269
|
+
statuses = [
|
270
|
+
Invoice::STATUS_CART,
|
271
|
+
Invoice::STATUS_PENDING,
|
272
|
+
Invoice::STATUS_READY_TO_SHIP,
|
273
|
+
Invoice::STATUS_SHIPPED,
|
274
|
+
Invoice::STATUS_CANCELED
|
275
|
+
]
|
276
|
+
options = statuses.collect{ |s| { 'text' => s.capitalize, 'value' => s }}
|
277
|
+
when 'payment-terms'
|
278
|
+
options = [
|
279
|
+
{ 'value' => Invoice::PAYMENT_TERMS_PIA , 'text' => 'Pay In Advance' },
|
280
|
+
{ 'value' => Invoice::PAYMENT_TERMS_NET7 , 'text' => 'Net 7' },
|
281
|
+
{ 'value' => Invoice::PAYMENT_TERMS_NET10 , 'text' => 'Net 10' },
|
282
|
+
{ 'value' => Invoice::PAYMENT_TERMS_NET30 , 'text' => 'Net 30' },
|
283
|
+
{ 'value' => Invoice::PAYMENT_TERMS_NET60 , 'text' => 'Net 60' },
|
284
|
+
{ 'value' => Invoice::PAYMENT_TERMS_NET90 , 'text' => 'Net 90' },
|
285
|
+
{ 'value' => Invoice::PAYMENT_TERMS_EOM , 'text' => 'End of Month' }
|
286
|
+
]
|
287
|
+
end
|
288
|
+
render :json => options
|
289
|
+
end
|
290
|
+
|
291
|
+
# @route GET /admin/invoices/google-feed
|
292
|
+
def admin_google_feed
|
293
|
+
d2 = DateTime.now
|
294
|
+
d1 = DateTime.now
|
295
|
+
if Caboose::Setting.exists?(:name => 'google_feed_date_last_submitted')
|
296
|
+
d1 = Caboose::Setting.where(:name => 'google_feed_date_last_submitted').first.value
|
297
|
+
d1 = DateTime.parse(d1)
|
298
|
+
elsif Invoice.exists?("status = ? and date_authorized is not null", Invoice::STATUS_SHIPPED)
|
299
|
+
d1 = Invoice.where("status = ? and date_authorized is not null", Invoice::STATUS_SHIPPED).reorder("date_authorized DESC").limit(1).pluck('date_authorized')
|
300
|
+
d1 = DateTime.parse(d1)
|
301
|
+
end
|
302
|
+
|
303
|
+
# Google Feed Docs
|
304
|
+
# https://support.google.com/trustedstoresmerchant/answer/3272612?hl=en&ref_topic=3272286?hl=en
|
305
|
+
tsv = ["merchant invoice id\ttracking number\tcarrier code\tother carrier name\tship date"]
|
306
|
+
if Invoice.exists?("status = ? and date_authorized > '#{d1.strftime("%F %T")}'", Invoice::STATUS_SHIPPED)
|
307
|
+
Invoice.where("status = ? and date_authorized > ?", Invoice::STATUS_SHIPPED, d1).reorder(:id).all.each do |invoice|
|
308
|
+
tracking_numbers = invoice.line_items.collect{ |li| li.tracking_number }.compact.uniq
|
309
|
+
tn = tracking_numbers && tracking_numbers.count >= 1 ? tracking_numbers[0] : ""
|
310
|
+
tsv << "#{invoice.id}\t#{tn}\tUPS\t\t#{invoice.date_shipped.strftime("%F")}"
|
311
|
+
end
|
312
|
+
end
|
313
|
+
|
314
|
+
# Save when we made the last call
|
315
|
+
setting = if Caboose::Setting.exists?(:name => 'google_feed_date_last_submitted')
|
316
|
+
Caboose::Setting.where(:name => 'google_feed_date_last_submitted').first
|
317
|
+
else
|
318
|
+
Caboose::Setting.new(:name => 'google_feed_date_last_submitted')
|
319
|
+
end
|
320
|
+
|
321
|
+
setting.value = d2.strftime("%F %T")
|
322
|
+
setting.save
|
323
|
+
|
324
|
+
# Print out the lines
|
325
|
+
render :text => tsv.join("\n")
|
326
|
+
end
|
327
|
+
end
|
328
|
+
end
|