spree_core 1.1.6 → 1.2.0.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (264) hide show
  1. data/app/assets/images/{creditcards → credit_cards}/amex_cid.gif +0 -0
  2. data/app/assets/images/{creditcards/creditcard.gif → credit_cards/credit_card.gif} +0 -0
  3. data/app/assets/images/{creditcards → credit_cards}/discover_cid.gif +0 -0
  4. data/app/assets/images/{creditcards → credit_cards}/icons/american_express.png +0 -0
  5. data/app/assets/images/{creditcards → credit_cards}/icons/cirrus.png +0 -0
  6. data/app/assets/images/{creditcards → credit_cards}/icons/delta.png +0 -0
  7. data/app/assets/images/{creditcards → credit_cards}/icons/dinersclub.png +0 -0
  8. data/app/assets/images/{creditcards → credit_cards}/icons/directdebit.png +0 -0
  9. data/app/assets/images/{creditcards → credit_cards}/icons/discover.png +0 -0
  10. data/app/assets/images/{creditcards → credit_cards}/icons/egold.png +0 -0
  11. data/app/assets/images/{creditcards → credit_cards}/icons/maestro.png +0 -0
  12. data/app/assets/images/{creditcards → credit_cards}/icons/master.png +0 -0
  13. data/app/assets/images/{creditcards → credit_cards}/icons/paypal.png +0 -0
  14. data/app/assets/images/{creditcards → credit_cards}/icons/solo.png +0 -0
  15. data/app/assets/images/{creditcards → credit_cards}/icons/switch.png +0 -0
  16. data/app/assets/images/{creditcards → credit_cards}/icons/visa.png +0 -0
  17. data/app/assets/images/{creditcards → credit_cards}/icons/visaelectron.png +0 -0
  18. data/app/assets/images/{creditcards → credit_cards}/icons/westernunion.png +0 -0
  19. data/app/assets/images/{creditcards → credit_cards}/icons/wirecard.png +0 -0
  20. data/app/assets/images/{creditcards → credit_cards}/icons/worldpay.png +0 -0
  21. data/app/assets/images/{creditcards → credit_cards}/master_cid.jpg +0 -0
  22. data/app/assets/images/{creditcards → credit_cards}/visa_cid.gif +0 -0
  23. data/app/assets/javascripts/admin/admin.js.erb +12 -136
  24. data/app/assets/javascripts/admin/checkouts/edit.js +18 -35
  25. data/app/assets/javascripts/admin/gateway.js +2 -2
  26. data/app/assets/javascripts/admin/images/index.js.coffee +12 -0
  27. data/app/assets/javascripts/admin/images/new.js.coffee +4 -0
  28. data/app/assets/javascripts/admin/orders/edit.js +1 -1
  29. data/app/assets/javascripts/admin/orders/edit_form.js +0 -2
  30. data/app/assets/javascripts/admin/product_autocomplete.js.erb +116 -0
  31. data/app/assets/javascripts/store/cart.js.coffee +7 -0
  32. data/app/assets/javascripts/store/checkout.js.coffee +57 -0
  33. data/app/assets/javascripts/store/product.js.coffee +36 -0
  34. data/app/assets/stylesheets/admin/admin.css.erb +5 -0
  35. data/app/assets/stylesheets/admin/spree_core.css +1 -0
  36. data/app/assets/stylesheets/store/screen.css.scss +15 -1
  37. data/app/assets/stylesheets/store/variables.css.scss +29 -29
  38. data/app/controllers/spree/admin/banners_controller.rb +14 -0
  39. data/app/controllers/spree/admin/base_controller.rb +11 -0
  40. data/app/controllers/spree/admin/images_controller.rb +13 -5
  41. data/app/controllers/spree/admin/line_items_controller.rb +16 -25
  42. data/app/controllers/spree/admin/mail_methods_controller.rb +1 -8
  43. data/app/controllers/spree/admin/option_types_controller.rb +0 -25
  44. data/app/controllers/spree/admin/orders/customer_details_controller.rb +3 -3
  45. data/app/controllers/spree/admin/orders_controller.rb +23 -14
  46. data/app/controllers/spree/admin/payment_methods_controller.rb +1 -7
  47. data/app/controllers/spree/admin/payments_controller.rb +5 -5
  48. data/app/controllers/spree/admin/products_controller.rb +15 -5
  49. data/app/controllers/spree/admin/prototypes_controller.rb +2 -2
  50. data/app/controllers/spree/admin/reports_controller.rb +1 -7
  51. data/app/controllers/spree/admin/resource_controller.rb +130 -130
  52. data/app/controllers/spree/admin/search_controller.rb +47 -0
  53. data/app/controllers/spree/admin/taxons_controller.rb +0 -43
  54. data/app/controllers/spree/base_controller.rb +2 -1
  55. data/app/controllers/spree/checkout_controller.rb +29 -10
  56. data/app/controllers/spree/orders_controller.rb +7 -11
  57. data/app/controllers/spree/products_controller.rb +5 -1
  58. data/app/helpers/spree/account_helper.rb +4 -0
  59. data/app/helpers/spree/admin/base_helper.rb +2 -44
  60. data/app/helpers/spree/admin/navigation_helper.rb +1 -3
  61. data/app/helpers/spree/admin/orders_helper.rb +3 -2
  62. data/app/helpers/spree/admin/products_helper.rb +21 -0
  63. data/app/helpers/spree/base_helper.rb +14 -11
  64. data/app/helpers/spree/checkout_helper.rb +5 -1
  65. data/app/helpers/spree/orders_helper.rb +5 -0
  66. data/app/helpers/spree/products_helper.rb +4 -0
  67. data/app/helpers/spree/trackers_helper.rb +4 -0
  68. data/app/models/spree/ability.rb +70 -0
  69. data/app/models/spree/address.rb +4 -12
  70. data/app/models/spree/adjustment.rb +30 -8
  71. data/app/models/spree/app_configuration.rb +1 -1
  72. data/app/models/spree/calculator/price_sack.rb +3 -5
  73. data/app/models/spree/country.rb +1 -4
  74. data/app/models/spree/{creditcard.rb → credit_card.rb} +4 -4
  75. data/app/models/spree/gateway.rb +2 -2
  76. data/app/models/spree/gateway/bogus.rb +10 -10
  77. data/app/models/spree/gateway/bogus_simple.rb +4 -4
  78. data/app/models/spree/image.rb +3 -12
  79. data/app/models/spree/inventory_unit.rb +4 -6
  80. data/app/models/spree/{user.rb → legacy_user.rb} +7 -6
  81. data/app/models/spree/line_item.rb +4 -5
  82. data/app/models/spree/option_type.rb +4 -6
  83. data/app/models/spree/option_value.rb +1 -1
  84. data/app/models/spree/order.rb +90 -132
  85. data/app/models/spree/order/checkout.rb +124 -0
  86. data/app/models/spree/payment.rb +6 -6
  87. data/app/models/spree/payment/processing.rb +34 -38
  88. data/app/models/spree/payment_method.rb +2 -2
  89. data/app/models/spree/preference.rb +2 -0
  90. data/app/models/spree/preferences/preferable_class_methods.rb +0 -2
  91. data/app/models/spree/preferences/store.rb +3 -21
  92. data/app/models/spree/product.rb +41 -43
  93. data/app/models/spree/product/scopes.rb +9 -25
  94. data/app/models/spree/product_option_type.rb +2 -2
  95. data/app/models/spree/product_property.rb +9 -4
  96. data/app/models/spree/property.rb +1 -1
  97. data/app/models/spree/prototype.rb +2 -2
  98. data/app/models/spree/return_authorization.rb +2 -2
  99. data/app/models/spree/role.rb +1 -1
  100. data/app/models/spree/shipment.rb +6 -5
  101. data/app/models/spree/shipping_method.rb +19 -13
  102. data/app/models/spree/state.rb +2 -5
  103. data/app/models/spree/state_change.rb +1 -1
  104. data/app/models/spree/tax_rate.rb +8 -1
  105. data/app/models/spree/taxon.rb +5 -1
  106. data/app/models/spree/taxonomy.rb +1 -1
  107. data/app/models/spree/tokenized_permission.rb +6 -0
  108. data/app/models/spree/tracker.rb +1 -1
  109. data/app/models/spree/variant.rb +13 -40
  110. data/app/models/spree/zone.rb +15 -14
  111. data/app/models/spree/zone_member.rb +1 -1
  112. data/app/views/spree/admin/image_settings/edit.html.erb +2 -2
  113. data/app/views/spree/admin/images/_form.html.erb +8 -4
  114. data/app/views/spree/admin/images/index.html.erb +1 -1
  115. data/app/views/spree/admin/line_items/create.js.erb +1 -1
  116. data/app/views/spree/admin/option_types/_option_value_fields.html.erb +1 -1
  117. data/app/views/spree/admin/option_types/index.html.erb +1 -1
  118. data/app/views/spree/admin/orders/_add_product.html.erb +1 -1
  119. data/app/views/spree/admin/orders/customer_details/edit.html.erb +1 -1
  120. data/app/views/spree/admin/orders/index.html.erb +4 -4
  121. data/app/views/spree/admin/orders/show.html.erb +1 -1
  122. data/app/views/spree/admin/payments/_form.html.erb +1 -1
  123. data/app/views/spree/admin/payments/new.html.erb +0 -4
  124. data/app/views/spree/admin/payments/source_forms/_gateway.html.erb +1 -1
  125. data/app/views/spree/admin/payments/source_views/_gateway.html.erb +2 -2
  126. data/app/views/spree/admin/products/_form.html.erb +21 -5
  127. data/app/views/spree/admin/products/index.html.erb +2 -2
  128. data/app/views/spree/admin/properties/_form.html.erb +1 -1
  129. data/app/views/spree/admin/properties/index.html.erb +1 -1
  130. data/app/views/spree/admin/return_authorizations/_form.html.erb +33 -17
  131. data/app/views/spree/admin/return_authorizations/edit.html.erb +2 -2
  132. data/app/views/spree/admin/shared/_address_form.html.erb +1 -1
  133. data/app/views/spree/admin/shared/_head.html.erb +12 -2
  134. data/app/views/spree/admin/shared/_order_tabs.html.erb +1 -4
  135. data/app/views/spree/admin/shared/_product_tabs.html.erb +0 -6
  136. data/app/views/spree/admin/shared/_show_resource_links.html.erb +3 -3
  137. data/app/views/spree/admin/shared/_tabs.html.erb +1 -2
  138. data/app/views/spree/admin/shipments/edit.html.erb +2 -2
  139. data/app/views/spree/admin/shipping_methods/_form.html.erb +1 -1
  140. data/app/views/spree/admin/states/_state_list.html.erb +1 -1
  141. data/app/views/spree/admin/tax_rates/index.html.erb +1 -1
  142. data/app/views/spree/admin/taxonomies/_form.html.erb +1 -1
  143. data/app/views/spree/admin/taxons/_form.html.erb +1 -1
  144. data/app/views/spree/admin/taxons/_taxon_table.html.erb +2 -2
  145. data/app/views/spree/admin/variants/_form.html.erb +13 -13
  146. data/app/views/spree/admin/variants/index.html.erb +1 -7
  147. data/app/views/spree/checkout/_address.html.erb +10 -4
  148. data/app/views/spree/checkout/edit.html.erb +0 -1
  149. data/app/views/spree/checkout/payment/_gateway.html.erb +5 -5
  150. data/app/views/spree/checkout/registration.html.erb +2 -2
  151. data/app/views/spree/content/cvv.html.erb +6 -6
  152. data/app/views/spree/layouts/spree_application.html.erb +4 -48
  153. data/app/views/spree/order_mailer/cancel_email.text.erb +5 -5
  154. data/app/views/spree/order_mailer/confirm_email.text.erb +6 -7
  155. data/app/views/spree/orders/_adjustments.html.erb +14 -0
  156. data/app/views/spree/orders/_form.html.erb +1 -0
  157. data/app/views/spree/orders/show.html.erb +3 -3
  158. data/app/views/spree/products/_thumbnails.html.erb +1 -1
  159. data/app/views/spree/products/index.html.erb +1 -1
  160. data/app/views/spree/shared/_footer.html.erb +6 -0
  161. data/app/views/spree/shared/_google_analytics.html.erb +15 -16
  162. data/app/views/spree/shared/_head.html.erb +3 -9
  163. data/app/views/spree/shared/_header.html.erb +5 -0
  164. data/app/views/spree/shared/_main_nav_bar.html.erb +6 -0
  165. data/app/views/spree/shared/_nav_bar.html.erb +7 -3
  166. data/app/views/spree/shared/_order_details.html.erb +14 -11
  167. data/app/views/spree/shared/_sidebar.html.erb +3 -0
  168. data/app/views/spree/shared/unauthorized.html.erb +0 -0
  169. data/app/views/spree/shipment_mailer/shipped_email.text.erb +7 -7
  170. data/app/views/spree/taxons/show.html.erb +1 -1
  171. data/config/initializers/check_for_orphaned_preferences.rb +1 -1
  172. data/config/initializers/spree.rb +0 -12
  173. data/config/initializers/user_class_extensions.rb +25 -0
  174. data/config/initializers/workarounds_for_ruby19.rb +72 -0
  175. data/config/locales/en.yml +11 -24
  176. data/config/routes.rb +7 -37
  177. data/db/migrate/20090823005402_spree_zero_nine_zero.rb +14 -12
  178. data/db/migrate/20091015153048_add_openid_field_to_users.rb +9 -7
  179. data/db/migrate/20100209144531_polymorphic_payments.rb +5 -5
  180. data/db/migrate/20100214212536_assign_creditcard_txns_to_payment.rb +4 -4
  181. data/db/migrate/20100528185820_add_index_on_users_persistence_token.rb +3 -1
  182. data/db/migrate/20100811163637_add_guest_flag.rb +3 -1
  183. data/db/migrate/20100901171814_change_guest_flag_to_anonymous.rb +3 -1
  184. data/db/migrate/20101026184959_generate_anonymous_users.rb +3 -3
  185. data/db/migrate/20101103212716_drop_anonymous_field_for_user.rb +3 -1
  186. data/db/migrate/20111007143030_namespace_top_level_models.rb +18 -1
  187. data/db/migrate/20120315064358_migrate_images_from_products_to_variants.rb +6 -4
  188. data/db/migrate/20120509055454_create_tokenized_permissions_table.rb +16 -0
  189. data/db/migrate/20120530012000_rename_creditcards_to_credit_cards.rb +11 -0
  190. data/db/migrate/20120604203654_remove_credit_total_from_orders.rb +5 -0
  191. data/lib/generators/spree/custom_user/custom_user_generator.rb +53 -0
  192. data/lib/generators/spree/custom_user/templates/authentication_helpers.rb.tt +28 -0
  193. data/lib/generators/spree/custom_user/templates/initializer.rb.tt +1 -0
  194. data/lib/generators/spree/custom_user/templates/migration.rb.tt +7 -0
  195. data/lib/generators/spree/dummy/dummy_generator.rb +3 -0
  196. data/lib/generators/spree/dummy/templates/initializers/custom_user.rb +1 -0
  197. data/lib/generators/spree/install/templates/app/assets/javascripts/admin/all.js +0 -1
  198. data/lib/generators/spree/install/templates/app/assets/javascripts/store/all.js +0 -1
  199. data/lib/generators/spree/install/templates/app/assets/stylesheets/admin/all.css +0 -1
  200. data/lib/generators/spree/install/templates/app/assets/stylesheets/store/all.css +0 -1
  201. data/lib/generators/spree/install/templates/config/initializers/spree.rb +2 -0
  202. data/lib/spree/core.rb +15 -2
  203. data/lib/spree/core/controller_helpers.rb +123 -62
  204. data/lib/spree/core/current_order.rb +5 -0
  205. data/lib/spree/core/engine.rb +1 -1
  206. data/lib/spree/core/mail_settings.rb +1 -2
  207. data/lib/spree/core/permalinks.rb +1 -5
  208. data/lib/spree/core/preference_rescue.rb +8 -4
  209. data/lib/spree/core/relation_serialization.rb +9 -0
  210. data/lib/spree/core/respond_with.rb +1 -1
  211. data/lib/spree/core/s3_support.rb +25 -0
  212. data/lib/spree/core/search/base.rb +2 -5
  213. data/lib/spree/core/ssl_requirement.rb +2 -2
  214. data/lib/spree/core/store_helpers.rb +1 -2
  215. data/lib/spree/core/testing_support/controller_requests.rb +1 -0
  216. data/lib/spree/core/testing_support/env.rb +2 -0
  217. data/lib/spree/core/testing_support/factories/{creditcard_factory.rb → credit_card_factory.rb} +3 -3
  218. data/lib/spree/core/testing_support/factories/payment_factory.rb +1 -1
  219. data/lib/spree/core/testing_support/factories/product_factory.rb +4 -4
  220. data/lib/spree/core/testing_support/factories/user_factory.rb +3 -3
  221. data/lib/spree/core/testing_support/factories/zone_factory.rb +2 -3
  222. data/lib/spree/core/token_resource.rb +27 -0
  223. data/lib/spree/core/version.rb +1 -1
  224. data/lib/spree/product_filters.rb +12 -13
  225. data/lib/tasks/core.rake +1 -1
  226. metadata +146 -154
  227. data/app/assets/images/noimage/large.png +0 -0
  228. data/app/assets/javascripts/admin/images/index.js +0 -10
  229. data/app/assets/javascripts/admin/images/new.js +0 -5
  230. data/app/assets/javascripts/admin/products.js +0 -2
  231. data/app/assets/javascripts/store/cart.js +0 -11
  232. data/app/assets/javascripts/store/checkout.js +0 -78
  233. data/app/assets/javascripts/store/product.js +0 -49
  234. data/app/controllers/spree/admin/users_controller.rb +0 -68
  235. data/app/views/spree/admin/option_types/_available.html.erb +0 -28
  236. data/app/views/spree/admin/option_types/_selected.html.erb +0 -26
  237. data/app/views/spree/admin/option_types/available.js.erb +0 -2
  238. data/app/views/spree/admin/option_types/select.js.erb +0 -3
  239. data/app/views/spree/admin/option_types/selected.html.erb +0 -6
  240. data/app/views/spree/admin/orders/history.html.erb +0 -29
  241. data/app/views/spree/admin/products/_option_types.html.erb +0 -40
  242. data/app/views/spree/admin/shared/_additional_field.html.erb +0 -5
  243. data/app/views/spree/admin/shared/_routes.html.erb +0 -8
  244. data/app/views/spree/admin/shared/_translations.html.erb +0 -17
  245. data/app/views/spree/admin/taxons/available.js.erb +0 -26
  246. data/app/views/spree/admin/taxons/remove.html.erb +0 -1
  247. data/app/views/spree/admin/taxons/select.js.erb +0 -2
  248. data/app/views/spree/admin/taxons/selected.html.erb +0 -42
  249. data/app/views/spree/admin/users/_form.html.erb +0 -19
  250. data/app/views/spree/admin/users/edit.html.erb +0 -14
  251. data/app/views/spree/admin/users/index.html.erb +0 -48
  252. data/app/views/spree/admin/users/new.html.erb +0 -14
  253. data/app/views/spree/admin/users/show.html.erb +0 -21
  254. data/app/views/spree/shared/_store_menu.html.erb +0 -2
  255. data/config/initializers/rails_5868.rb +0 -8
  256. data/db/migrate/20120605211305_make_users_email_index_unique.rb +0 -10
  257. data/db/migrate/20121017010007_remove_not_null_constraint_from_products_on_hand.rb +0 -11
  258. data/db/sample/users.rb +0 -61
  259. data/lib/generators/spree/sandbox/sandbox_generator.rb +0 -36
  260. data/lib/generators/spree/sandbox/templates/rails/routes.rb +0 -7
  261. data/lib/spree/core/ext/array.rb +0 -14
  262. data/lib/spree/core/ext/hash.rb +0 -75
  263. data/lib/spree/core/ext/string.rb +0 -10
  264. data/lib/tasks/install.rake +0 -18
@@ -27,11 +27,11 @@ module Spree
27
27
  end
28
28
 
29
29
  add_search_scope :ascend_by_master_price do
30
- joins(:master).order("#{variant_table_name}.price ASC")
30
+ joins(:variants_with_only_master).order("#{variant_table_name}.price ASC")
31
31
  end
32
32
 
33
33
  add_search_scope :descend_by_master_price do
34
- joins(:master).order("#{variant_table_name}.price DESC")
34
+ joins(:variants_with_only_master).order("#{variant_table_name}.price DESC")
35
35
  end
36
36
 
37
37
  add_search_scope :price_between do |low, high|
@@ -50,23 +50,8 @@ module Spree
50
50
  # If you need products only within one taxon use
51
51
  #
52
52
  # Spree::Product.taxons_id_eq(x)
53
- #
54
- # If you're using count on the result of this scope, you must use the
55
- # `:distinct` option as well:
56
- #
57
- # Spree::Product.in_taxon(taxon).count(:distinct => true)
58
- #
59
- # This is so that the count query is distinct'd:
60
- #
61
- # SELECT COUNT(DISTINCT "spree_products"."id") ...
62
- #
63
- # vs.
64
- #
65
- # SELECT COUNT(*) ...
66
53
  add_search_scope :in_taxon do |taxon|
67
- select("DISTINCT(spree_products.id), spree_products.*").
68
- joins(:taxons).
69
- where(Taxon.table_name => { :id => taxon.self_and_descendants.map(&:id) })
54
+ joins(:taxons).where(Taxon.table_name => { :id => taxon.self_and_descendants.map(&:id) })
70
55
  end
71
56
 
72
57
  # This scope selects products in all taxons AND all its descendants
@@ -128,7 +113,7 @@ module Spree
128
113
  end
129
114
 
130
115
  conditions = "#{option_values}.name = ? AND #{option_values}.option_type_id = ?", value, option_type_id
131
- group("spree_products.id").joins(:variants_including_master => :option_values).where(conditions)
116
+ select("DISTINCT spree_products.id").joins(:variants_including_master => :option_values).where(conditions)
132
117
  end
133
118
 
134
119
  # Finds all products which have either:
@@ -203,11 +188,11 @@ module Spree
203
188
 
204
189
  add_search_scope :on_hand do
205
190
  variants_table = Variant.table_name
206
- where("#{table_name}.id in (select product_id from #{variants_table} where product_id = #{table_name}.id and #{variants_table}.deleted_at IS NULL group by product_id having sum(count_on_hand) > 0)")
191
+ where("#{table_name}.id in (select product_id from #{variants_table} where product_id = #{table_name}.id group by product_id having sum(count_on_hand) > 0)")
207
192
  end
208
193
 
209
194
  add_search_scope :taxons_name_eq do |name|
210
- group("spree_products.id").joins(:taxons).where(Taxon.arel_table[:name].eq(name))
195
+ select("DISTINCT spree_products.id").joins(:taxons).where(Taxon.arel_table[:name].eq(name))
211
196
  end
212
197
 
213
198
  if (ActiveRecord::Base.connection.adapter_name == 'PostgreSQL')
@@ -220,6 +205,7 @@ module Spree
220
205
  search_scopes << :group_by_products_id
221
206
 
222
207
  private
208
+
223
209
  def self.variant_table_name
224
210
  Variant.quoted_table_name
225
211
  end
@@ -239,16 +225,14 @@ module Spree
239
225
  end
240
226
 
241
227
  def self.get_taxons(*ids_or_records_or_names)
242
- taxons = Spree::Taxon.table_name
228
+ taxons = Taxon.table_name
243
229
  ids_or_records_or_names.flatten.map { |t|
244
230
  case t
245
231
  when Integer then Taxon.find_by_id(t)
246
232
  when ActiveRecord::Base then t
247
233
  when String
248
234
  Taxon.find_by_name(t) ||
249
- Taxon.find(:first, :conditions => [
250
- "#{taxons}.permalink LIKE ? OR #{taxons}.permalink = ?", "%/#{t}/", "#{t}/"
251
- ])
235
+ Taxon.where("#{taxons}.permalink LIKE ? OR #{taxons}.permalink = ?", "%/#{t}/", "#{t}/").first
252
236
  end
253
237
  }.compact.flatten.uniq
254
238
  end
@@ -1,7 +1,7 @@
1
1
  module Spree
2
2
  class ProductOptionType < ActiveRecord::Base
3
- belongs_to :product, :class_name => "Spree::Product"
4
- belongs_to :option_type, :class_name => "Spree::OptionType"
3
+ belongs_to :product
4
+ belongs_to :option_type
5
5
  acts_as_list :scope => :product
6
6
  end
7
7
  end
@@ -1,10 +1,10 @@
1
1
  module Spree
2
2
  class ProductProperty < ActiveRecord::Base
3
- belongs_to :product, :class_name => "Spree::Product"
4
- belongs_to :property, :class_name => "Spree::Property"
3
+ belongs_to :product
4
+ belongs_to :property
5
5
 
6
6
  validates :property, :presence => true
7
- validates_length_of :value, :maximum => 255
7
+ validates :value, :length => { :maximum => 255 }
8
8
 
9
9
  attr_accessible :property_name, :value
10
10
 
@@ -14,7 +14,12 @@ module Spree
14
14
  end
15
15
 
16
16
  def property_name=(name)
17
- self.property = Property.find_by_name(name) unless name.blank?
17
+ unless name.blank?
18
+ unless property = Property.find_by_name(name)
19
+ property = Property.create(:name => name, :presentation => name)
20
+ end
21
+ self.property = property
22
+ end
18
23
  end
19
24
  end
20
25
  end
@@ -1,6 +1,6 @@
1
1
  module Spree
2
2
  class Property < ActiveRecord::Base
3
- has_and_belongs_to_many :prototypes, :join_table => 'spree_properties_prototypes'
3
+ has_and_belongs_to_many :prototypes, :join_table => :spree_properties_prototypes
4
4
 
5
5
  has_many :product_properties, :dependent => :destroy
6
6
  has_many :products, :through => :product_properties
@@ -1,7 +1,7 @@
1
1
  module Spree
2
2
  class Prototype < ActiveRecord::Base
3
- has_and_belongs_to_many :properties, :join_table => 'spree_properties_prototypes'
4
- has_and_belongs_to_many :option_types, :join_table => 'spree_option_types_prototypes'
3
+ has_and_belongs_to_many :properties, :join_table => :spree_properties_prototypes
4
+ has_and_belongs_to_many :option_types, :join_table => :spree_option_types_prototypes
5
5
 
6
6
  attr_accessible :name
7
7
 
@@ -1,6 +1,7 @@
1
1
  module Spree
2
2
  class ReturnAuthorization < ActiveRecord::Base
3
- belongs_to :order, :class_name => "Spree::Order"
3
+ belongs_to :order
4
+
4
5
  has_many :inventory_units
5
6
  before_create :generate_number
6
7
  before_save :force_positive_amount
@@ -71,7 +72,6 @@ module Spree
71
72
  credit.source = self
72
73
  credit.adjustable = order
73
74
  credit.save
74
- order.return if inventory_units.all?{ |inventory_unit| inventory_unit.returned? }
75
75
  end
76
76
 
77
77
  def allow_receive?
@@ -2,6 +2,6 @@ module Spree
2
2
  class Role < ActiveRecord::Base
3
3
  attr_accessible :name
4
4
 
5
- has_and_belongs_to_many :users, :join_table => 'spree_roles_users'
5
+ has_and_belongs_to_many :users, :join_table => 'spree_roles_users', :class_name => Spree.user_class.to_s
6
6
  end
7
7
  end
@@ -2,9 +2,10 @@ require 'ostruct'
2
2
 
3
3
  module Spree
4
4
  class Shipment < ActiveRecord::Base
5
- belongs_to :order, :class_name => "Spree::Order"
6
- belongs_to :shipping_method, :class_name => "Spree::ShippingMethod"
7
- belongs_to :address, :class_name => "Spree::Address"
5
+ belongs_to :order
6
+ belongs_to :shipping_method
7
+ belongs_to :address
8
+
8
9
  has_many :state_changes, :as => :stateful
9
10
  has_many :inventory_units, :dependent => :nullify
10
11
  has_one :adjustment, :as => :source, :dependent => :destroy
@@ -26,7 +27,7 @@ module Spree
26
27
  make_permalink :field => :number
27
28
 
28
29
  scope :shipped, where(:state => 'shipped')
29
- scope :ready, where(:state => 'ready')
30
+ scope :ready, where(:state => 'ready')
30
31
  scope :pending, where(:state => 'pending')
31
32
 
32
33
  def to_param
@@ -117,7 +118,7 @@ module Spree
117
118
  # shipped if already shipped (ie. does not change the state)
118
119
  # ready all other cases
119
120
  def determine_state(order)
120
- return 'pending' if self.inventory_units.any? { |unit| unit.backordered? }
121
+ return 'pending' if inventory_units.any? &:backordered?
121
122
  return 'shipped' if state == 'shipped'
122
123
  order.paid? ? 'ready' : 'pending'
123
124
  end
@@ -1,14 +1,11 @@
1
1
  module Spree
2
2
  class ShippingMethod < ActiveRecord::Base
3
3
  DISPLAY = [:both, :front_end, :back_end]
4
-
5
- default_scope where(:deleted_at => nil)
6
-
7
4
  has_many :shipments
8
5
  validates :name, :zone, :presence => true
9
6
 
10
- belongs_to :shipping_category, :class_name => "Spree::ShippingCategory"
11
- belongs_to :zone, :class_name => "Spree::Zone"
7
+ belongs_to :shipping_category
8
+ belongs_to :zone
12
9
 
13
10
  attr_accessible :name, :zone_id, :display_on, :shipping_category_id,
14
11
  :match_none, :match_one, :match_all
@@ -16,16 +13,25 @@ module Spree
16
13
  calculated_adjustments
17
14
 
18
15
  def available?(order, display_on = nil)
19
- display_check = (self.display_on == display_on.to_s || self.display_on.blank?)
20
- calculator_check = calculator.available?(order)
21
- display_check && calculator_check
16
+ displayable? && calculator.available?(order)
17
+ end
18
+
19
+ def displayable?
20
+ (self.display_on == display_on.to_s || self.display_on.blank?)
21
+ end
22
+
23
+ def calculator_available?(order)
24
+ caluclator.available?(order)
25
+ end
26
+
27
+ def within_zone?(order)
28
+ zone && zone.include?(order.ship_address)
22
29
  end
23
30
 
24
- def available_to_order?(order, display_on = nil)
25
- availability_check = available?(order,display_on)
26
- zone_check = zone && zone.include?(order.ship_address)
27
- category_check = category_match?(order)
28
- availability_check && zone_check && category_check
31
+ def available_to_order?(order, display_on= nil)
32
+ available?(order, display_on) &&
33
+ within_zone?(order) &&
34
+ category_match?(order)
29
35
  end
30
36
 
31
37
  # Indicates whether or not the category rules for this shipping method
@@ -1,9 +1,6 @@
1
1
  module Spree
2
2
  class State < ActiveRecord::Base
3
- belongs_to :country, :class_name => "Spree::Country"
4
-
5
- has_one :zone_member, :as => :zoneable
6
- has_one :zone, :through => :zone_member
3
+ belongs_to :country
7
4
 
8
5
  validates :country, :name, :presence => true
9
6
 
@@ -17,7 +14,7 @@ module Spree
17
14
  # blank is added elsewhere, if needed
18
15
  def self.states_group_by_country_id
19
16
  state_info = Hash.new { |h, k| h[k] = [] }
20
- Spree::State.order('name ASC').each { |state|
17
+ self.order('name ASC').each { |state|
21
18
  state_info[state.country_id.to_s].push [state.id, state.name]
22
19
  }
23
20
  state_info
@@ -1,6 +1,6 @@
1
1
  module Spree
2
2
  class StateChange < ActiveRecord::Base
3
- belongs_to :user, :class_name => "Spree::User"
3
+ belongs_to :user
4
4
  belongs_to :stateful, :polymorphic => true
5
5
  before_create :assign_user
6
6
 
@@ -30,6 +30,13 @@ module Spree
30
30
  end
31
31
  end
32
32
 
33
+ def self.adjust(order)
34
+ order.clear_adjustments!
35
+ self.match(order).each do |rate|
36
+ rate.adjust(order)
37
+ end
38
+ end
39
+
33
40
  # For Vat the default rate is the rate that is configured for the default category
34
41
  # It is needed for every price calculation (as all customer facing prices include vat )
35
42
  # The function returns the actual amount, which may be 0 in case of wrong setup, but is never nil
@@ -64,9 +71,9 @@ module Spree
64
71
  end
65
72
 
66
73
  private
74
+
67
75
  def create_label
68
76
  "#{tax_category.name} #{amount * 100}%"
69
77
  end
70
78
  end
71
-
72
79
  end
@@ -2,8 +2,9 @@ module Spree
2
2
  class Taxon < ActiveRecord::Base
3
3
  acts_as_nested_set :dependent => :destroy
4
4
 
5
- belongs_to :taxonomy, :class_name => "Spree::Taxonomy"
5
+ belongs_to :taxonomy
6
6
  has_and_belongs_to_many :products, :join_table => 'spree_products_taxons'
7
+
7
8
  before_create :set_permalink
8
9
 
9
10
  attr_accessible :name, :parent_id, :position, :icon, :description, :permalink, :taxonomy_id
@@ -17,6 +18,9 @@ module Spree
17
18
  :path => ':rails_root/public/spree/taxons/:id/:style/:basename.:extension',
18
19
  :default_url => '/assets/default_taxon.png'
19
20
 
21
+ include Spree::Core::S3Support
22
+ supports_s3 :icon
23
+
20
24
  include ::Spree::ProductFilters # for detailed defs of filters
21
25
 
22
26
  # indicate which filters should be used for a taxon
@@ -5,7 +5,7 @@ module Spree
5
5
  attr_accessible :name
6
6
 
7
7
  has_many :taxons
8
- has_one :root, :conditions => { :parent_id => nil }, :class_name => 'Spree::Taxon',
8
+ has_one :root, :conditions => { :parent_id => nil }, :class_name => "Spree::Taxon",
9
9
  :dependent => :destroy
10
10
 
11
11
  after_save :set_name
@@ -0,0 +1,6 @@
1
+ module Spree
2
+ class TokenizedPermission < ActiveRecord::Base
3
+ belongs_to :permissable, :polymorphic => true
4
+ end
5
+ end
6
+
@@ -3,7 +3,7 @@ module Spree
3
3
  attr_accessible :analytics_id, :environment, :active
4
4
 
5
5
  def self.current
6
- tracker = first(:conditions => { :active => true, :environment => Rails.env })
6
+ tracker = where(:active => true, :environment => Rails.env).first
7
7
  tracker.analytics_id.present? ? tracker : nil if tracker
8
8
  end
9
9
  end
@@ -1,6 +1,6 @@
1
1
  module Spree
2
2
  class Variant < ActiveRecord::Base
3
- belongs_to :product, :touch => true, :class_name => "Spree::Product"
3
+ belongs_to :product, :touch => true
4
4
 
5
5
  delegate_belongs_to :product, :name, :description, :permalink, :available_on,
6
6
  :tax_category_id, :shipping_category_id, :meta_description,
@@ -13,7 +13,7 @@ module Spree
13
13
 
14
14
  has_many :inventory_units
15
15
  has_many :line_items
16
- has_and_belongs_to_many :option_values, :join_table => 'spree_option_values_variants'
16
+ has_and_belongs_to_many :option_values, :join_table => :spree_option_values_variants
17
17
  has_many :images, :as => :viewable, :order => :position, :dependent => :destroy
18
18
 
19
19
  validate :check_price
@@ -21,19 +21,12 @@ module Spree
21
21
  validates :cost_price, :numericality => { :greater_than_or_equal_to => 0, :allow_nil => true } if self.table_exists? && self.column_names.include?('cost_price')
22
22
  validates :count_on_hand, :numericality => true
23
23
 
24
- before_save :touch_product
25
24
  after_save :recalculate_product_on_hand, :if => :is_master?
26
25
 
27
26
  # default variant scope only lists non-deleted variants
28
27
  scope :active, where(:deleted_at => nil)
29
28
  scope :deleted, where('deleted_at IS NOT NULL')
30
29
 
31
- # default extra fields for shipping purposes
32
- @fields = [{ :name => 'Weight', :only => [:variant], :format => '%.2f' },
33
- { :name => 'Height', :only => [:variant], :format => '%.2f' },
34
- { :name => 'Width', :only => [:variant], :format => '%.2f' },
35
- { :name => 'Depth', :only => [:variant], :format => '%.2f' }]
36
-
37
30
  # Returns number of inventory units for this variant (new records haven't been saved to database, yet)
38
31
  def on_hand
39
32
  Spree::Config[:track_inventory_levels] ? count_on_hand : (1.0 / 0) # Infinity
@@ -58,12 +51,18 @@ module Spree
58
51
  end
59
52
  end
60
53
 
54
+ # strips all non-price-like characters from the price.
61
55
  def price=(price)
62
- self[:price] = parse_price(price) if price.present?
56
+ if price.present?
57
+ self[:price] = price.to_s.gsub(/[^0-9\.-]/, '').to_f
58
+ end
63
59
  end
64
60
 
61
+ # and cost_price
65
62
  def cost_price=(price)
66
- self[:cost_price] = parse_price(price) if price.present?
63
+ if price.present?
64
+ self[:cost_price] = price.to_s.gsub(/[^0-9\.-]/, '').to_f
65
+ end
67
66
  end
68
67
 
69
68
  # returns number of units currently on backorder for this variant.
@@ -77,17 +76,6 @@ module Spree
77
76
  end
78
77
  alias in_stock in_stock?
79
78
 
80
- def self.additional_fields
81
- ActiveSupport::Deprecation.warn("[SPREE] Spree::Variant.additional_fields will be deprecated in Spree 1.2. Please use Deface and decorators as an alternative to this functionality now.")
82
- @fields
83
- end
84
-
85
- def self.additional_fields=(new_fields)
86
- ActiveSupport::Deprecation.warn("[SPREE] Spree::Variant.additional_fields= will be deprecated in Spree 1.2. Please use Deface and decorators as an alternative to this functionality now.")
87
- attr_accessible *new_fields
88
- @fields = new_fields
89
- end
90
-
91
79
  # returns true if this variant is allowed to be placed on a new order
92
80
  def available?
93
81
  Spree::Config[:track_inventory_levels] ? (Spree::Config[:allow_backorders] || in_stock?) : true
@@ -118,7 +106,7 @@ module Spree
118
106
  # no option values on master
119
107
  return if self.is_master
120
108
 
121
- option_type = Spree::OptionType.find_or_initialize_by_name(opt_name) do |o|
109
+ option_type = Spree::OptionType.where(:name => opt_name).first_or_initialize do |o|
122
110
  o.presentation = opt_name
123
111
  o.save!
124
112
  end
@@ -136,7 +124,7 @@ module Spree
136
124
  end
137
125
  end
138
126
 
139
- option_value = Spree::OptionValue.find_or_initialize_by_option_type_id_and_name(option_type.id, opt_value) do |o|
127
+ option_value = Spree::OptionValue.where(:option_type_id => option_type.id, :name => opt_value).first_or_initialize do |o|
140
128
  o.presentation = opt_value
141
129
  o.save!
142
130
  end
@@ -149,19 +137,8 @@ module Spree
149
137
  self.option_values.detect { |o| o.option_type.name == opt_name }.try(:presentation)
150
138
  end
151
139
 
152
- private
153
-
154
- # strips all non-price-like characters from the price, taking into account locale settings
155
- def parse_price(price)
156
- return price unless price.is_a?(String)
157
140
 
158
- separator, delimiter = I18n.t([:'number.currency.format.separator', :'number.currency.format.delimiter'])
159
- non_price_characters = /[^0-9\-#{separator}]/
160
- price.gsub!(non_price_characters, '') # strip everything else first
161
- price.gsub!(separator, '.') unless separator == '.' # then replace the locale-specific decimal separator with the standard separator if necessary
162
-
163
- price.to_d
164
- end
141
+ private
165
142
 
166
143
  # Ensures a new variant takes the product master price when price is not supplied
167
144
  def check_price
@@ -171,10 +148,6 @@ module Spree
171
148
  end
172
149
  end
173
150
 
174
- def touch_product
175
- product.touch unless is_master?
176
- end
177
-
178
151
  def recalculate_product_on_hand
179
152
  on_hand = product.on_hand
180
153
  if Spree::Config[:track_inventory_levels] && on_hand != (1.0 / 0) # Infinity