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.
Files changed (193) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/caboose/{admin_edit_order.js → admin_edit_invoice.js} +332 -189
  3. data/app/assets/javascripts/caboose/cart.js +15 -15
  4. data/app/assets/javascripts/caboose/cart_old.js +2 -2
  5. data/app/assets/javascripts/caboose/checkout/authnet_payment_method_controller.js +120 -0
  6. data/app/assets/javascripts/caboose/checkout/billing_address_controller.js +85 -0
  7. data/app/assets/javascripts/caboose/checkout/cart_controller.js +257 -0
  8. data/app/assets/javascripts/caboose/checkout/checkout_controller.js +258 -0
  9. data/app/assets/javascripts/caboose/checkout/gift_cards_controller.js +57 -0
  10. data/app/assets/javascripts/caboose/checkout/shipping_address_controller.js +86 -0
  11. data/app/assets/javascripts/caboose/checkout/shipping_method_controller.js +121 -0
  12. data/app/assets/javascripts/caboose/checkout/stripe_payment_method_controller.js +155 -0
  13. data/app/assets/javascripts/caboose/checkout_login_register.js +2 -2
  14. data/app/assets/javascripts/caboose/checkout_module.js +8 -8
  15. data/app/assets/javascripts/caboose/checkout_old.js +151 -0
  16. data/app/assets/javascripts/caboose/{checkout_payment.js → checkout_payment_authnet.js} +1 -1
  17. data/app/assets/javascripts/caboose/checkout_payment_stripe.js +212 -0
  18. data/app/assets/javascripts/caboose/checkout_shipping.js +1 -1
  19. data/app/assets/javascripts/caboose/jquery.payment.js +1 -0
  20. data/app/assets/javascripts/caboose/model/attribute.js +3 -2
  21. data/app/assets/javascripts/caboose/model/bound_control.js +56 -14
  22. data/app/assets/javascripts/caboose/model/bound_select.js +9 -11
  23. data/app/assets/javascripts/caboose/model/bound_select_simple.js +215 -0
  24. data/app/assets/javascripts/caboose/model/bound_text.js +7 -8
  25. data/app/assets/javascripts/caboose/{my_account_edit_order.js → my_account_edit_invoice.js} +55 -55
  26. data/app/assets/javascripts/caboose/united_states.js +65 -0
  27. data/app/assets/stylesheets/caboose/{my_account_edit_order.css.scss → my_account_edit_invoice.css.scss} +1 -1
  28. data/app/assets/templates/caboose/cart/line_items.jst.ejs +3 -3
  29. data/app/assets/templates/caboose/checkout/line_items.jst.ejs +7 -7
  30. data/app/controllers/caboose/ab_options_controller.rb +4 -4
  31. data/app/controllers/caboose/ab_variants_controller.rb +5 -5
  32. data/app/controllers/caboose/admin_controller.rb +0 -6
  33. data/app/controllers/caboose/application_controller.rb +16 -15
  34. data/app/controllers/caboose/billing_addresses_controller.rb +22 -22
  35. data/app/controllers/caboose/block_type_sources_controller.rb +8 -8
  36. data/app/controllers/caboose/block_types_controller.rb +2 -42
  37. data/app/controllers/caboose/blocks_controller.rb +26 -26
  38. data/app/controllers/caboose/calendars_controller.rb +5 -5
  39. data/app/controllers/caboose/cart_controller.rb +55 -36
  40. data/app/controllers/caboose/categories_controller.rb +78 -76
  41. data/app/controllers/caboose/checkout_controller.rb +313 -340
  42. data/app/controllers/caboose/checkout_controller_bak.rb +620 -0
  43. data/app/controllers/caboose/domains_controller.rb +5 -5
  44. data/app/controllers/caboose/event_groups_controller.rb +26 -4
  45. data/app/controllers/caboose/events_controller.rb +7 -6
  46. data/app/controllers/caboose/fonts_controller.rb +2 -2
  47. data/app/controllers/caboose/gift_cards_controller.rb +113 -139
  48. data/app/controllers/caboose/google_spreadsheets_controller.rb +1 -1
  49. data/app/controllers/caboose/{order_packages_controller.rb → invoice_packages_controller.rb} +49 -49
  50. data/app/controllers/caboose/{order_reports_controller.rb → invoice_reports_controller.rb} +11 -13
  51. data/app/controllers/caboose/invoice_transactions_controller.rb +35 -0
  52. data/app/controllers/caboose/invoices_controller.rb +328 -0
  53. data/app/controllers/caboose/line_items_controller.rb +35 -34
  54. data/app/controllers/caboose/login_controller.rb +7 -7
  55. data/app/controllers/caboose/login_logs_controller.rb +4 -4
  56. data/app/controllers/caboose/logout_controller.rb +3 -1
  57. data/app/controllers/caboose/media_categories_controller.rb +9 -9
  58. data/app/controllers/caboose/media_controller.rb +21 -46
  59. data/app/controllers/caboose/modal_controller.rb +4 -3
  60. data/app/controllers/caboose/modification_values_controller.rb +6 -6
  61. data/app/controllers/caboose/modifications_controller.rb +7 -6
  62. data/app/controllers/caboose/my_account_controller.rb +2 -2
  63. data/app/controllers/caboose/my_account_invoices_controller.rb +166 -0
  64. data/app/controllers/caboose/my_account_line_items_controller.rb +15 -13
  65. data/app/controllers/caboose/page_custom_fields_controller.rb +9 -8
  66. data/app/controllers/caboose/page_permissions_controller.rb +3 -3
  67. data/app/controllers/caboose/pages_controller.rb +132 -135
  68. data/app/controllers/caboose/permissions_controller.rb +8 -7
  69. data/app/controllers/caboose/post_categories_controller.rb +22 -7
  70. data/app/controllers/caboose/post_custom_fields_controller.rb +9 -8
  71. data/app/controllers/caboose/posts_controller.rb +35 -43
  72. data/app/controllers/caboose/product_images_controller.rb +5 -5
  73. data/app/controllers/caboose/products_controller.rb +53 -47
  74. data/app/controllers/caboose/redirects_controller.rb +7 -7
  75. data/app/controllers/caboose/register_controller.rb +2 -2
  76. data/app/controllers/caboose/retargeting_controller.rb +2 -61
  77. data/app/controllers/caboose/reviews_controller.rb +1 -0
  78. data/app/controllers/caboose/roles_controller.rb +10 -9
  79. data/app/controllers/caboose/settings_controller.rb +9 -7
  80. data/app/controllers/caboose/shipping_addresses_controller.rb +18 -18
  81. data/app/controllers/caboose/shipping_packages_controller.rb +24 -21
  82. data/app/controllers/caboose/sites_controller.rb +35 -25
  83. data/app/controllers/caboose/smtp_controller.rb +3 -3
  84. data/app/controllers/caboose/sns_controller.rb +6 -6
  85. data/app/controllers/caboose/social_controller.rb +5 -6
  86. data/app/controllers/caboose/stackable_groups_controller.rb +10 -8
  87. data/app/controllers/caboose/station_controller.rb +3 -3
  88. data/app/controllers/caboose/store_controller.rb +93 -87
  89. data/app/controllers/caboose/subscriptions_controller.rb +153 -0
  90. data/app/controllers/caboose/users_controller.rb +25 -22
  91. data/app/controllers/caboose/variants_controller.rb +72 -93
  92. data/app/controllers/caboose/vendors_controller.rb +35 -32
  93. data/app/mailers/caboose/{orders_mailer.rb → invoices_mailer.rb} +21 -21
  94. data/app/mailers/caboose/login_mailer.rb +3 -3
  95. data/app/models/caboose/authnet.rb +295 -195
  96. data/app/models/caboose/comment_routes.rb +68 -41
  97. data/app/models/caboose/core_plugin.rb +1 -1
  98. data/app/models/caboose/discount.rb +14 -3
  99. data/app/models/caboose/domain_constraint.rb +11 -3
  100. data/app/models/caboose/gift_card.rb +8 -8
  101. data/app/models/caboose/invoice.rb +706 -0
  102. data/app/models/caboose/invoice_discount.rb +10 -0
  103. data/app/models/caboose/invoice_package.rb +76 -0
  104. data/app/models/caboose/{order_package_calculator.rb → invoice_package_calculator.rb} +20 -20
  105. data/app/models/caboose/{order_pdf.rb → invoice_pdf.rb} +30 -30
  106. data/app/models/caboose/{order_reporter.rb → invoice_reporter.rb} +5 -5
  107. data/app/models/caboose/invoice_transaction.rb +169 -0
  108. data/app/models/caboose/line_item.rb +11 -8
  109. data/app/models/caboose/payment_processors/authorizenet.rb +15 -15
  110. data/app/models/caboose/payment_processors/base.rb +3 -3
  111. data/app/models/caboose/{pending_orders_pdf.rb → pending_invoices_pdf.rb} +31 -31
  112. data/app/models/caboose/product.rb +2 -4
  113. data/app/models/caboose/schema.rb +159 -111
  114. data/app/models/caboose/shipping_calculator.rb +41 -139
  115. data/app/models/caboose/smtp_config.rb +2 -1
  116. data/app/models/caboose/store_config.rb +7 -7
  117. data/app/models/caboose/subscription.rb +32 -0
  118. data/app/models/caboose/tax_calculator.rb +36 -36
  119. data/app/models/caboose/user.rb +6 -0
  120. data/app/models/caboose/user_subscription.rb +142 -0
  121. data/app/models/caboose/wish_list.rb +14 -0
  122. data/app/models/caboose/wish_list_line_item.rb +13 -0
  123. data/app/views/caboose/blocks/_products.html.erb +10 -13
  124. data/app/views/caboose/checkout/_address_form.html.erb +14 -14
  125. data/app/views/caboose/checkout/_billing_form.html.erb +3 -3
  126. data/app/views/caboose/checkout/_cart.html.erb +7 -7
  127. data/app/views/caboose/checkout/_cart_old.html.erb +9 -9
  128. data/app/views/caboose/checkout/_confirm.html.erb +9 -9
  129. data/app/views/caboose/checkout/_order_discount.html.erb +3 -3
  130. data/app/views/caboose/checkout/_shipping_address.html.erb +1 -1
  131. data/app/views/caboose/checkout/_shipping_method.html.erb +1 -1
  132. data/app/views/caboose/checkout/addresses.html.erb +10 -10
  133. data/app/views/caboose/checkout/authnet.html.erb +34 -0
  134. data/app/views/caboose/checkout/authnet_response_handler.html.erb +3 -0
  135. data/app/views/caboose/checkout/checkout.html.erb +100 -0
  136. data/app/views/caboose/checkout/confirm_without_payment.html.erb +6 -6
  137. data/app/views/caboose/checkout/discount.html.erb +1 -1
  138. data/app/views/caboose/checkout/index.html.erb +4 -4
  139. data/app/views/caboose/checkout/payment_authnet.html.erb +140 -0
  140. data/app/views/caboose/checkout/payment_stripe.html.erb +95 -0
  141. data/app/views/caboose/checkout/shipping.html.erb +4 -4
  142. data/app/views/caboose/checkout/thanks.html.erb +3 -3
  143. data/app/views/caboose/gift_cards/admin_edit.html.erb +19 -19
  144. data/app/views/caboose/gift_cards/admin_index.html.erb +9 -9
  145. data/app/views/caboose/{orders → invoices}/_admin_footer.html.erb +0 -0
  146. data/app/views/caboose/{orders → invoices}/_admin_header.html.erb +0 -0
  147. data/app/views/caboose/{orders/_quickbooks_order.html.erb → invoices/_quickbooks_invoice.html.erb} +0 -0
  148. data/app/views/caboose/{orders → invoices}/admin_city_report.html.erb +1 -1
  149. data/app/views/caboose/invoices/admin_delete_form.html.erb +18 -0
  150. data/app/views/caboose/{orders → invoices}/admin_edit.html.erb +14 -14
  151. data/app/views/caboose/{orders → invoices}/admin_index.html.erb +24 -24
  152. data/app/views/caboose/{orders → invoices}/admin_invalid_order.html.erb +2 -2
  153. data/app/views/caboose/{orders → invoices}/admin_new.html.erb +7 -7
  154. data/app/views/caboose/{orders → invoices}/admin_print.html.erb +15 -15
  155. data/app/views/caboose/{orders → invoices}/admin_summary_report.html.erb +4 -4
  156. data/app/views/caboose/{orders_mailer/customer_new_order.html.erb → invoices_mailer/customer_new_invoice.html.erb} +21 -21
  157. data/app/views/caboose/invoices_mailer/customer_payment_authorization.html.erb +5 -0
  158. data/app/views/caboose/{orders_mailer → invoices_mailer}/customer_status_updated.html.erb +22 -22
  159. data/app/views/caboose/{orders_mailer/fulfillment_new_order.html.erb → invoices_mailer/fulfillment_new_invoice.html.erb} +23 -23
  160. data/app/views/caboose/{orders_mailer/shipping_order_ready.html.erb → invoices_mailer/shipping_invoice_ready.html.erb} +0 -0
  161. data/app/views/caboose/{orders_mailer → invoices_mailer}/test_email.html.erb +0 -0
  162. data/app/views/caboose/line_items/admin_new.html.erb +1 -1
  163. data/app/views/caboose/login_mailer/forgot_password_email.html.erb +2 -3
  164. data/app/views/caboose/my_account/index.html.erb +1 -1
  165. data/app/views/caboose/{my_account_orders → my_account_invoices}/authnet_relay.html.erb +0 -0
  166. data/app/views/caboose/{my_account_orders → my_account_invoices}/authnet_response.html.erb +0 -0
  167. data/app/views/caboose/{my_account_orders → my_account_invoices}/edit.html.erb +9 -9
  168. data/app/views/caboose/my_account_invoices/index.html.erb +36 -0
  169. data/app/views/caboose/{my_account_orders → my_account_invoices}/payment_form.html.erb +10 -10
  170. data/app/views/caboose/post_categories/admin_index.html.erb +1 -1
  171. data/app/views/caboose/sites/admin_edit.html.erb +1 -1
  172. data/app/views/caboose/store/admin_edit_general.html.erb +5 -3
  173. data/app/views/caboose/store/admin_edit_packages.html.erb +6 -6
  174. data/app/views/caboose/store/admin_edit_shipping.html.erb +3 -3
  175. data/app/views/caboose/store/admin_edit_tax.html.erb +1 -1
  176. data/app/views/caboose/subscriptions/admin_edit.html.erb +82 -0
  177. data/app/views/caboose/subscriptions/admin_index.html.erb +45 -0
  178. data/config/routes.rb +1 -759
  179. data/config/routes_old.rb +759 -0
  180. data/lib/caboose/version.rb +1 -1
  181. data/lib/tasks/caboose.rake +41 -15
  182. metadata +101 -61
  183. data/app/controllers/caboose/my_account_orders_controller.rb +0 -165
  184. data/app/controllers/caboose/orders_controller.rb +0 -310
  185. data/app/models/caboose/order.rb +0 -479
  186. data/app/models/caboose/order_discount.rb +0 -10
  187. data/app/models/caboose/order_package.rb +0 -133
  188. data/app/models/caboose/order_transaction.rb +0 -41
  189. data/app/models/caboose/payment_processors/payscape.rb +0 -94
  190. data/app/views/caboose/checkout/payment.html.erb +0 -146
  191. data/app/views/caboose/my_account_orders/index.html.erb +0 -36
  192. data/app/views/caboose/orders/admin_delete_form.html.erb +0 -21
  193. data/app/views/caboose/orders_mailer/customer_payment_authorization.html.erb +0 -5
@@ -1,165 +0,0 @@
1
- module Caboose
2
- class MyAccountOrdersController < Caboose::ApplicationController
3
-
4
- helper :authorize_net
5
- protect_from_forgery :except => :authnet_relay
6
-
7
- # GET /my-account/orders
8
- def index
9
- return if !verify_logged_in
10
-
11
- @pager = Caboose::PageBarGenerator.new(params, {
12
- 'customer_id' => logged_in_user.id,
13
- 'status' => [Order::STATUS_PENDING, Order::STATUS_CANCELED, Order::STATUS_READY_TO_SHIP, Order::STATUS_SHIPPED]
14
- }, {
15
- 'model' => 'Caboose::Order',
16
- 'sort' => 'order_number',
17
- 'desc' => 1,
18
- 'base_url' => '/my-account/orders',
19
- 'use_url_params' => false
20
- })
21
- @orders = @pager.all_items
22
- end
23
-
24
- # GET /my-account/orders/:id
25
- def edit
26
- return if !verify_logged_in
27
-
28
- @order = Order.find(params[:id])
29
- if @order.customer_id != logged_in_user.id
30
- @error = "The given order does not belong to you."
31
- render :file => 'caboose/extras/error'
32
- return
33
- end
34
- end
35
-
36
- # GET /my-account/orders/:id/payment-form
37
- def payment_form
38
- return if !logged_in?
39
-
40
- @order = Order.find(params[:id])
41
- if @order.customer_id != logged_in_user.id
42
- @error = "The given order does not belong to you."
43
- render :file => 'caboose/extras/error'
44
- return
45
- end
46
-
47
- if @order.financial_status != Order::FINANCIAL_STATUS_PENDING
48
- @error = "This order does not require payment at this time."
49
- render :file => 'caboose/extras/error'
50
- return
51
- end
52
-
53
- sc = @site.store_config
54
- case sc.pp_name
55
- when 'authorize.net'
56
-
57
- @sim_transaction = AuthorizeNet::SIM::Transaction.new(
58
- sc.authnet_api_login_id,
59
- sc.authnet_api_transaction_key,
60
- @order.total,
61
- :relay_response => 'TRUE',
62
- :relay_url => "#{sc.authnet_relay_domain}/my-account/orders/authnet-relay",
63
- :transaction_type => 'AUTH_ONLY',
64
- :test => sc.pp_testing
65
- )
66
- @request = request
67
- @show_relay = params[:show_relay] && params[:show_relay].to_i == 1
68
-
69
- when 'stripe'
70
- # TODO: Implement manual order payment for stripe
71
-
72
- end
73
- render :layout => false
74
- end
75
-
76
- # GET /my-account/orders/:id/json
77
- def order_json
78
- return if !logged_in?
79
-
80
- order = Order.find(params[:id])
81
- if order.customer_id != logged_in_user.id
82
- render :json => { :error => "The given order does not belong to you." }
83
- return
84
- end
85
-
86
- if order.shipping_address_id.nil?
87
- sa = Address.create
88
- order.shipping_address_id = sa.id
89
- order.save
90
- end
91
- render :json => order.as_json(:include => [
92
- { :line_items => { :include => { :variant => { :include => :product }}}},
93
- { :order_packages => { :include => [:shipping_package, :shipping_method] }},
94
- { :discounts => { :include => :gift_card }},
95
- :customer,
96
- :shipping_address,
97
- :billing_address,
98
- :order_transactions
99
- ])
100
- end
101
-
102
- # POST /my-account/orders/authnet-relay
103
- def authnet_relay
104
- Caboose.log("Authorize.net relay for my account, order #{params[:x_invoice_id]}")
105
-
106
- order = Caboose::Order.find(params[:x_invoice_num])
107
- ot = Caboose::OrderTransaction.new(
108
- :order_id => order.id,
109
- :date_processed => DateTime.now.utc,
110
- :transaction_type => Caboose::OrderTransaction::TYPE_AUTHORIZE
111
- )
112
- ot.success = params[:x_response_code] && params[:x_response_code] == '1'
113
- ot.transaction_id = params[:x_trans_id] if params[:x_trans_id]
114
- ot.auth_code = params[:x_auth_code] if params[:x_auth_code]
115
- ot.response_code = params[:x_response_code] if params[:x_response_code]
116
- ot.amount = order.total
117
- ot.save
118
-
119
- error = nil
120
- if ot.success
121
- order.financial_status = Order::FINANCIAL_STATUS_AUTHORIZED
122
- order.status = Order::STATUS_PENDING if order.status == Order::STATUS_CART
123
- order.order_number = @site.store_config.next_order_number if order.order_number.nil?
124
-
125
- # Send out emails
126
- OrdersMailer.configure_for_site(@site.id).customer_new_order(order).deliver
127
-
128
- # Emit order event
129
- Caboose.plugin_hook('order_authorized', order)
130
- else
131
- order.financial_status = Order::FINANCIAL_STATUS_PENDING
132
- error = "There was a problem processing your payment."
133
- end
134
-
135
- order.save
136
-
137
- @url = params[:x_after_relay]
138
- @url << (ot.success ? "?success=1" : "?error=#{error}")
139
-
140
- render :layout => false
141
- end
142
-
143
- # GET /my-account/orders/:id/authnet-response
144
- # POST /my-account/orders/:id/authnet-response
145
- def authnet_response
146
- Caboose.log("Authorize.net response for my account, order #{params[:id]}")
147
-
148
- @resp = Caboose::StdClass.new
149
- @resp.success = true if params[:success]
150
- @resp.error = params[:error] if params[:error]
151
-
152
- # Go ahead and capture funds if the order only contained downloadable items
153
- @order = Order.find(params[:id])
154
- if !@order.has_shippable_items?
155
- capture_resp = @order.capture_funds
156
- if capture_resp.error
157
- @resp.success = false
158
- @resp.error = capture_resp.error
159
- end
160
- end
161
- render :layout => false
162
- end
163
-
164
- end
165
- end
@@ -1,310 +0,0 @@
1
- module Caboose
2
- class OrdersController < Caboose::ApplicationController
3
-
4
- # GET /admin/orders/weird-test
5
- def admin_weird_test
6
- Caboose.log("Before the admin_weird_test")
7
- x = Order.new
8
- Caboose.log("After the admin_weird_test")
9
- render :json => x
10
- end
11
-
12
- # GET /admin/orders
13
- def admin_index
14
- return if !user_is_allowed('orders', 'view')
15
-
16
- @pager = Caboose::PageBarGenerator.new(params, {
17
- 'site_id' => @site.id,
18
- 'customer_id' => '',
19
- 'status' => Order::STATUS_PENDING,
20
- 'shipping_method_code' => '',
21
- 'id' => '',
22
- 'order_number' => ''
23
- }, {
24
- 'model' => 'Caboose::Order',
25
- 'sort' => 'id',
26
- 'desc' => 1,
27
- 'base_url' => '/admin/orders',
28
- 'use_url_params' => false,
29
- 'items_per_page' => 100
30
- })
31
-
32
- @orders = @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
- # GET /admin/orders/new
39
- def admin_new
40
- return if !user_is_allowed('orders', 'add')
41
- render :layout => 'caboose/admin'
42
- end
43
-
44
- # POST /admin/orders
45
- def admin_add
46
- return if !user_is_allowed('orders', 'add')
47
- order = Order.create(
48
- :site_id => @site.id,
49
- :status => Order::STATUS_PENDING,
50
- :financial_status => Order::FINANCIAL_STATUS_PENDING,
51
- :order_number => @site.store_config.next_order_number
52
- )
53
- render :json => { :sucess => true, :redirect => "/admin/orders/#{order.id}" }
54
- end
55
-
56
- # GET /admin/orders/:id
57
- def admin_edit
58
- return if !user_is_allowed('orders', 'edit')
59
- @order = Order.where(:id => params[:id]).first
60
-
61
- if params[:id].nil? || @order.nil?
62
- render :file => 'caboose/orders/admin_invalid_order', :layout => 'caboose/admin'
63
- return
64
- end
65
- render :layout => 'caboose/admin'
66
- end
67
-
68
- # GET /admin/orders/:id/calculate-tax
69
- def admin_calculate_tax
70
- return if !user_is_allowed('orders', 'edit')
71
- order = Order.find(params[:id])
72
- order.tax = order.calculate_tax
73
- order.total = order.calculate_total
74
- order.save
75
- render :json => { :success => true }
76
- end
77
-
78
- # GET /admin/orders/:id/calculate-handling
79
- def admin_calculate_handling
80
- return if !user_is_allowed('orders', 'edit')
81
- order = Order.find(params[:id])
82
- order.handling = order.calculate_handling
83
- order.total = order.calculate_total
84
- order.save
85
- render :json => { :success => true }
86
- end
87
-
88
- # GET /admin/orders/:id/capture
89
- def capture_funds
90
- return if !user_is_allowed('orders', 'edit')
91
-
92
- order = Order.find(params[:id])
93
- resp = order.capture_funds
94
-
95
- # Tell taxcloud the order was captured
96
- #Caboose::TaxCalculator.captured(order)
97
-
98
- render :json => resp
99
- end
100
-
101
- # GET /admin/orders/:id/void
102
- def admin_void
103
- return if !user_is_allowed('orders', 'edit')
104
-
105
- order = Order.find(params[:id])
106
- resp = order.void
107
-
108
- render :json => resp
109
- end
110
-
111
- # GET /admin/orders/:id/refund
112
- def admin_refund
113
- return if !user_is_allowed('orders', 'edit')
114
-
115
- order = Order.find(params[:id])
116
- resp = order.refund
117
-
118
- render :json => resp
119
- end
120
-
121
- # POST /admin/orders/:id/resend-confirmation
122
- def admin_resend_confirmation
123
- if Order.find(params[:id]).resend_confirmation
124
- render :json => { success: "Confirmation re-sent successfully." }
125
- else
126
- render :json => { error: "There was an error re-sending the email." }
127
- end
128
- end
129
-
130
- # GET /admin/orders/:id/json
131
- def admin_json
132
- return if !user_is_allowed('orders', 'edit')
133
- order = Order.find(params[:id])
134
- if order.shipping_address_id.nil?
135
- sa = Address.create
136
- order.shipping_address_id = sa.id
137
- order.save
138
- end
139
- render :json => order.as_json(:include => [
140
- { :line_items => { :include => { :variant => { :include => :product }}}},
141
- { :order_packages => { :include => [:shipping_package, :shipping_method] }},
142
- { :discounts => { :include => :gift_card }},
143
- :customer,
144
- :shipping_address,
145
- :billing_address,
146
- :order_transactions
147
- ])
148
- end
149
-
150
- # GET /admin/orders/:id/print.pdf
151
- def admin_print
152
- return if !user_is_allowed('orders', 'edit')
153
-
154
- pdf = OrderPdf.new
155
- pdf.order = Order.find(params[:id])
156
- send_data pdf.to_pdf, :filename => "order_#{pdf.order.id}.pdf", :type => "application/pdf", :disposition => "inline"
157
- end
158
-
159
- # GET /admin/orders/print-pending
160
- def admin_print_pending
161
- return if !user_is_allowed('orders', 'edit')
162
-
163
- pdf = PendingOrdersPdf.new
164
- if params[:print_card_details]
165
- pdf.print_card_details = params[:print_card_details].to_i == 1
166
- end
167
- pdf.orders = Order.where(:site_id => @site.id, :status => Order::STATUS_PENDING).all
168
- send_data pdf.to_pdf, :filename => "pending_orders.pdf", :type => "application/pdf", :disposition => "inline"
169
- end
170
-
171
- # PUT /admin/orders/:id
172
- def admin_update
173
- return if !user_is_allowed('orders', 'edit')
174
-
175
- resp = Caboose::StdClass.new({'attributes' => {}})
176
- order = Order.find(params[:id])
177
-
178
- save = true
179
- params.each do |name,value|
180
- case name
181
- when 'tax' then
182
- order.tax = value
183
- order.total = order.calculate_total
184
- when 'handling' then
185
- order.handling = value
186
- order.total = order.calculate_total
187
- when 'custom_discount' then
188
- order.custom_discount = value
189
- order.discount = order.calculate_discount
190
- order.total = order.calculate_total
191
- when 'status' then
192
- order.status = value
193
- if value == 'Shipped'
194
- order.date_shipped = DateTime.now.utc
195
- end
196
- when 'customer_id' then order.customer_id = value
197
- end
198
- end
199
-
200
- #order.calculate
201
- #order.calculate_total
202
- #resp.attributes['total'] = { 'value' => order.total }
203
-
204
- resp.success = save && order.save
205
- render :json => resp
206
- end
207
-
208
- # DELETE /admin/orders/:id
209
- def admin_delete
210
- return if !user_is_allowed('orders', 'delete')
211
- Order.find(params[:id]).destroy
212
- render :json => Caboose::StdClass.new({
213
- :redirect => '/admin/orders'
214
- })
215
- end
216
-
217
- # GET /admin/orders/:id/send-for-authorization
218
- def admin_send_for_authorization
219
- return if !user_is_allowed('orders', 'edit')
220
- order = Order.find(params[:id])
221
- order.delay.send_payment_authorization_email
222
- render :json => { :success => true }
223
- end
224
-
225
- # GET /admin/orders/city-report
226
- def admin_city_report
227
- return if !user_is_allowed('orders', 'view')
228
-
229
- @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')
230
- @d2 = params[:d2] ? DateTime.strptime("#{params[:d2]} 00:00:00", '%Y-%m-%d %H:%M:%S') : @d1 + 1.month
231
- @rows = OrderReporter.city_report(@site.id, @d1, @d2)
232
-
233
- render :layout => 'caboose/admin'
234
- end
235
-
236
- # GET /admin/orders/summary-report
237
- def admin_summary_report
238
- return if !user_is_allowed('orders', 'view')
239
-
240
- @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')
241
- @d2 = params[:d2] ? DateTime.strptime("#{params[:d2]} 00:00:00", '%Y-%m-%d %H:%M:%S') : @d1 + 1.month
242
- @rows = OrderReporter.summary_report(@site.id, @d1, @d2)
243
-
244
- render :layout => 'caboose/admin'
245
- end
246
-
247
- # GET /admin/orders/status-options
248
- def admin_status_options
249
- return if !user_is_allowed('orders', 'view')
250
- statuses = [
251
- Order::STATUS_CART,
252
- Order::STATUS_PENDING,
253
- Order::STATUS_READY_TO_SHIP,
254
- Order::STATUS_SHIPPED,
255
- Order::STATUS_CANCELED
256
- ]
257
- options = statuses.collect{ |s| { 'text' => s.capitalize, 'value' => s }}
258
- render :json => options
259
- end
260
-
261
- # GET /admin/orders/test-info
262
- def admin_mail_test_info
263
- TestMailer.test_info.deliver
264
- render :text => "Sent email to info@tuskwearcollection.com on #{DateTime.now.strftime("%F %T")}"
265
- end
266
-
267
- # GET /admin/orders/test-gmail
268
- def admin_mail_test_gmail
269
- TestMailer.test_gmail.deliver
270
- render :text => "Sent email to william@nine.is on #{DateTime.now.strftime("%F %T")}"
271
- end
272
-
273
- # GET /admin/orders/google-feed
274
- def admin_google_feed
275
- d2 = DateTime.now
276
- d1 = DateTime.now
277
- if Caboose::Setting.exists?(:name => 'google_feed_date_last_submitted')
278
- d1 = Caboose::Setting.where(:name => 'google_feed_date_last_submitted').first.value
279
- d1 = DateTime.parse(d1)
280
- elsif Order.exists?("status = ? and date_authorized is not null", Order::STATUS_SHIPPED)
281
- d1 = Order.where("status = ? and date_authorized is not null", Order::STATUS_SHIPPED).reorder("date_authorized DESC").limit(1).pluck('date_authorized')
282
- d1 = DateTime.parse(d1)
283
- end
284
-
285
- # Google Feed Docs
286
- # https://support.google.com/trustedstoresmerchant/answer/3272612?hl=en&ref_topic=3272286?hl=en
287
- tsv = ["merchant order id\ttracking number\tcarrier code\tother carrier name\tship date"]
288
- if Order.exists?("status = ? and date_authorized > '#{d1.strftime("%F %T")}'", Order::STATUS_SHIPPED)
289
- Order.where("status = ? and date_authorized > ?", Order::STATUS_SHIPPED, d1).reorder(:id).all.each do |order|
290
- tracking_numbers = order.line_items.collect{ |li| li.tracking_number }.compact.uniq
291
- tn = tracking_numbers && tracking_numbers.count >= 1 ? tracking_numbers[0] : ""
292
- tsv << "#{order.id}\t#{tn}\tUPS\t\t#{order.date_shipped.strftime("%F")}"
293
- end
294
- end
295
-
296
- # Save when we made the last call
297
- setting = if Caboose::Setting.exists?(:name => 'google_feed_date_last_submitted')
298
- Caboose::Setting.where(:name => 'google_feed_date_last_submitted').first
299
- else
300
- Caboose::Setting.new(:name => 'google_feed_date_last_submitted')
301
- end
302
-
303
- setting.value = d2.strftime("%F %T")
304
- setting.save
305
-
306
- # Print out the lines
307
- render :text => tsv.join("\n")
308
- end
309
- end
310
- end