spree_core 0.40.4 → 0.50.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (251) hide show
  1. data/README.md +6 -1
  2. data/app/controllers/admin/base_controller.rb +0 -57
  3. data/app/controllers/admin/configurations_controller.rb +1 -1
  4. data/app/controllers/admin/general_settings_controller.rb +1 -1
  5. data/app/controllers/admin/images_controller.rb +18 -8
  6. data/app/controllers/admin/inventory_settings_controller.rb +1 -1
  7. data/app/controllers/admin/mail_settings_controller.rb +1 -1
  8. data/app/controllers/admin/option_types_controller.rb +11 -0
  9. data/app/controllers/admin/orders_controller.rb +16 -20
  10. data/app/controllers/admin/overview_controller.rb +1 -1
  11. data/app/controllers/admin/payment_methods_controller.rb +6 -6
  12. data/app/controllers/admin/product_groups_controller.rb +10 -11
  13. data/app/controllers/admin/product_properties_controller.rb +5 -5
  14. data/app/controllers/admin/product_scopes_controller.rb +12 -4
  15. data/app/controllers/admin/products_controller.rb +17 -12
  16. data/app/controllers/admin/properties_controller.rb +7 -7
  17. data/app/controllers/admin/prototypes_controller.rb +15 -15
  18. data/app/controllers/admin/reports_controller.rb +12 -11
  19. data/app/controllers/admin/shipments_controller.rb +0 -5
  20. data/app/controllers/admin/shipping_categories_controller.rb +6 -6
  21. data/app/controllers/admin/shipping_methods_controller.rb +1 -2
  22. data/app/controllers/admin/states_controller.rb +12 -12
  23. data/app/controllers/admin/tax_categories_controller.rb +2 -2
  24. data/app/controllers/admin/tax_rates_controller.rb +8 -8
  25. data/app/controllers/admin/tax_settings_controller.rb +1 -1
  26. data/app/controllers/admin/taxonomies_controller.rb +3 -3
  27. data/app/controllers/admin/taxons_controller.rb +1 -8
  28. data/app/controllers/admin/trackers_controller.rb +1 -1
  29. data/app/controllers/admin/users_controller.rb +6 -9
  30. data/app/controllers/admin/variants_controller.rb +13 -2
  31. data/app/controllers/admin/zones_controller.rb +9 -9
  32. data/app/controllers/checkout_controller.rb +5 -5
  33. data/app/controllers/products_controller.rb +1 -1
  34. data/app/controllers/taxons_controller.rb +3 -1
  35. data/app/helpers/admin/navigation_helper.rb +36 -19
  36. data/app/helpers/admin/payments_helper.rb +1 -1
  37. data/app/helpers/admin/product_groups_helper.rb +1 -1
  38. data/app/helpers/admin/product_properties_helper.rb +5 -5
  39. data/app/helpers/admin/products_helper.rb +2 -2
  40. data/app/helpers/admin/users_helper.rb +5 -2
  41. data/app/helpers/hook_helper.rb +3 -3
  42. data/app/helpers/products_helper.rb +0 -19
  43. data/app/helpers/spree/base_helper.rb +33 -2
  44. data/app/helpers/taxons_helper.rb +3 -3
  45. data/app/mailers/order_mailer.rb +2 -2
  46. data/app/mailers/shipment_mailer.rb +2 -2
  47. data/app/models/address.rb +42 -9
  48. data/app/models/adjustment.rb +8 -8
  49. data/app/models/app_configuration.rb +0 -6
  50. data/app/models/billing_integration.rb +1 -1
  51. data/app/models/calculator/sales_tax.rb +3 -3
  52. data/app/models/configuration.rb +1 -1
  53. data/app/models/country.rb +4 -5
  54. data/app/models/creditcard.rb +38 -31
  55. data/app/models/gateway.rb +14 -14
  56. data/app/models/gateway/beanstream.rb +4 -4
  57. data/app/models/gateway/bogus.rb +6 -6
  58. data/app/models/gateway/braintree.rb +88 -0
  59. data/app/models/gateway/eway.rb +3 -3
  60. data/app/models/image.rb +5 -4
  61. data/app/models/option_type.rb +1 -0
  62. data/app/models/order.rb +60 -21
  63. data/app/models/payment.rb +5 -32
  64. data/app/models/preference.rb +7 -7
  65. data/app/models/product.rb +22 -7
  66. data/app/models/product_group.rb +22 -26
  67. data/app/models/product_property.rb +5 -5
  68. data/app/models/product_scope.rb +26 -6
  69. data/app/models/property.rb +1 -1
  70. data/app/models/state.rb +2 -3
  71. data/app/models/tax_category.rb +1 -0
  72. data/app/models/tax_rate.rb +1 -2
  73. data/app/models/taxon.rb +12 -10
  74. data/app/models/taxonomy.rb +7 -4
  75. data/app/models/tracker.rb +1 -1
  76. data/app/models/user.rb +4 -0
  77. data/app/models/variant.rb +1 -1
  78. data/app/models/zone.rb +1 -1
  79. data/app/models/zone_member.rb +3 -3
  80. data/app/views/admin/{shared → adjustments}/_adjustments_table.html.erb +7 -4
  81. data/app/views/admin/adjustments/edit.html.erb +1 -1
  82. data/app/views/admin/adjustments/index.html.erb +2 -2
  83. data/app/views/admin/adjustments/new.html.erb +2 -1
  84. data/app/views/admin/general_settings/edit.html.erb +4 -12
  85. data/app/views/admin/general_settings/show.html.erb +0 -5
  86. data/app/views/admin/images/index.html.erb +8 -5
  87. data/app/views/admin/inventory_settings/show.html.erb +1 -1
  88. data/app/views/admin/mail_methods/index.html.erb +4 -4
  89. data/app/views/admin/option_types/_form.html.erb +4 -4
  90. data/app/views/admin/option_types/_option_value_fields.html.erb +2 -2
  91. data/app/views/admin/option_types/edit.html.erb +4 -2
  92. data/app/views/admin/option_types/index.html.erb +5 -5
  93. data/app/views/admin/orders/_line_item.html.erb +2 -1
  94. data/app/views/admin/orders/history.html.erb +6 -2
  95. data/app/views/admin/orders/index.html.erb +22 -19
  96. data/app/views/admin/orders/show.html.erb +1 -1
  97. data/app/views/admin/orders/user.html.erb +1 -1
  98. data/app/views/admin/payment_methods/index.html.erb +7 -5
  99. data/app/views/admin/payments/_list.html.erb +3 -3
  100. data/app/views/admin/payments/index.html.erb +1 -1
  101. data/app/views/admin/payments/show.html.erb +2 -2
  102. data/app/views/admin/product_groups/edit.html.erb +7 -7
  103. data/app/views/admin/product_groups/index.html.erb +5 -3
  104. data/app/views/admin/product_groups/update.js.erb +4 -3
  105. data/app/views/admin/product_properties/_product_property_fields.html.erb +3 -3
  106. data/app/views/admin/product_properties/index.html.erb +10 -5
  107. data/app/views/admin/product_scopes/destroy.js.erb +1 -0
  108. data/app/views/admin/products/index.html.erb +32 -33
  109. data/app/views/admin/properties/_form.html.erb +2 -2
  110. data/app/views/admin/properties/index.html.erb +4 -4
  111. data/app/views/admin/prototypes/index.html.erb +4 -4
  112. data/app/views/admin/shared/_address_form.html.erb +1 -1
  113. data/app/views/admin/shared/_calculator_fields.html.erb +1 -1
  114. data/app/views/admin/shared/_destroy.js.erb +15 -2
  115. data/app/views/admin/shared/_order_tabs.html.erb +1 -1
  116. data/app/views/admin/shared/_report_criteria.html.erb +1 -1
  117. data/app/views/admin/shipments/_form.html.erb +6 -2
  118. data/app/views/admin/shipments/edit.html.erb +1 -1
  119. data/app/views/admin/shipments/index.html.erb +4 -2
  120. data/app/views/admin/shipping_methods/_form.html.erb +2 -0
  121. data/app/views/admin/shipping_methods/index.html.erb +3 -2
  122. data/app/views/admin/states/_state_list.html.erb +11 -5
  123. data/app/views/admin/tax_categories/index.html.erb +9 -4
  124. data/app/views/admin/tax_settings/show.html.erb +2 -2
  125. data/app/views/admin/taxonomies/_list.html.erb +4 -2
  126. data/app/views/admin/taxonomies/index.html.erb +2 -2
  127. data/app/views/admin/taxons/_form.html.erb +1 -1
  128. data/app/views/admin/trackers/index.html.erb +5 -5
  129. data/app/views/admin/users/_form.html.erb +3 -4
  130. data/app/views/admin/users/index.html.erb +7 -6
  131. data/app/views/admin/users/show.html.erb +3 -3
  132. data/app/views/admin/variants/index.html.erb +21 -6
  133. data/app/views/admin/zones/_form.html.erb +9 -9
  134. data/app/views/admin/zones/_member_type.html.erb +5 -5
  135. data/app/views/admin/zones/index.html.erb +7 -5
  136. data/app/views/checkout/_address.html.erb +2 -2
  137. data/app/views/checkout/_payment.html.erb +3 -6
  138. data/app/views/layouts/admin.html.erb +3 -9
  139. data/app/views/layouts/spree_application.html.erb +2 -1
  140. data/app/views/orders/_line_item.html.erb +1 -1
  141. data/app/views/orders/edit.html.erb +17 -16
  142. data/app/views/orders/show.html.erb +1 -1
  143. data/app/views/shared/_admin_head.html.erb +1 -1
  144. data/app/views/shared/_error_messages.html.erb +2 -2
  145. data/app/views/shared/_filters.html.erb +4 -4
  146. data/app/views/shared/_head.html.erb +2 -2
  147. data/app/views/shared/_nav_bar.html.erb +2 -2
  148. data/app/views/shared/_products.html.erb +4 -2
  149. data/app/views/shared/_taxonomies.html.erb +15 -8
  150. data/app/views/shipment_mailer/shipped_email.text.erb +2 -2
  151. data/config/cucumber.yml +10 -0
  152. data/config/initializers/form_builder.rb +1 -5
  153. data/config/initializers/workarounds_for_ruby19.rb +5 -5
  154. data/config/locales/en.yml +33 -6
  155. data/config/routes.rb +18 -13
  156. data/db/migrate/20090923100315_add_count_on_hand_to_variants_and_products.rb +5 -5
  157. data/db/migrate/20091213222815_creditcard_last_four_digits.rb +5 -5
  158. data/db/migrate/20100105132138_shipment_id_for_inventory_units.rb +2 -2
  159. data/db/migrate/20100209025806_create_payment_methods.rb +3 -3
  160. data/db/migrate/20100209144531_polymorphic_payments.rb +1 -1
  161. data/db/migrate/20100214212536_assign_creditcard_txns_to_payment.rb +2 -2
  162. data/db/migrate/20100224153127_deleted_at_for_payment_methods.rb +1 -1
  163. data/db/migrate/20100506185838_add_description_to_taxons.rb +1 -1
  164. data/db/migrate/20100816212146_shipping_method_id_for_orders.rb +1 -1
  165. data/db/migrate/20101026184808_migrate_checkout_to_orders.rb +2 -2
  166. data/db/migrate/20101223215658_add_position_to_variants.rb +9 -0
  167. data/db/migrate/20110110130847_add_next_state_to_state_events.rb +9 -0
  168. data/db/migrate/20110111122537_add_position_to_option_types.rb +9 -0
  169. data/db/migrate/20110314192118_remove_trailing_slashes_in_taxon_permalinks.rb +17 -0
  170. data/lib/custom_fixtures.rb +1 -1
  171. data/lib/{seo_assist.rb → middleware/seo_assist.rb} +14 -8
  172. data/lib/product_filters.rb +49 -43
  173. data/lib/redirect_legacy_product_url.rb +5 -5
  174. data/lib/scopes.rb +2 -2
  175. data/lib/scopes/dynamic.rb +9 -16
  176. data/lib/scopes/product.rb +33 -16
  177. data/lib/scopes/variant.rb +4 -3
  178. data/lib/spree/calculated_adjustments.rb +5 -2
  179. data/lib/spree/config.rb +2 -0
  180. data/lib/spree/current_order.rb +4 -4
  181. data/lib/spree/mail_settings.rb +3 -2
  182. data/lib/spree/search/base.rb +9 -10
  183. data/lib/spree_base.rb +22 -23
  184. data/lib/spree_core.rb +10 -69
  185. data/lib/spree_core/authorize_net_cim_hack.rb +1 -1
  186. data/lib/spree_core/delegate_belongs_to.rb +18 -24
  187. data/lib/spree_core/enumerable_constants.rb +38 -38
  188. data/lib/spree_core/find_by_param.rb +8 -6
  189. data/lib/spree_core/preferences/preference_definition.rb +7 -7
  190. data/lib/spree_core/railtie.rb +58 -0
  191. data/lib/spree_core/ssl_requirement.rb +4 -3
  192. data/lib/spree_core/testing_support/factories.rb +13 -0
  193. data/lib/spree_core/testing_support/factories/address_factory.rb +20 -0
  194. data/lib/spree_core/testing_support/factories/adjustment_factory.rb +6 -0
  195. data/lib/spree_core/testing_support/factories/calculator_factory.rb +5 -0
  196. data/lib/spree_core/testing_support/factories/configuraion_factory.rb +4 -0
  197. data/lib/spree_core/testing_support/factories/country_factory.rb +7 -0
  198. data/lib/spree_core/testing_support/factories/creditcard_factory.rb +11 -0
  199. data/lib/spree_core/testing_support/factories/inventory_unit_factory.rb +7 -0
  200. data/lib/spree_core/testing_support/factories/line_item_factory.rb +8 -0
  201. data/lib/spree_core/testing_support/factories/mail_method_factory.rb +4 -0
  202. data/lib/spree_core/testing_support/factories/options_factory.rb +10 -0
  203. data/lib/spree_core/testing_support/factories/order_factory.rb +18 -0
  204. data/lib/spree_core/testing_support/factories/payment_factory.rb +26 -0
  205. data/lib/spree_core/testing_support/factories/payment_method_factory.rb +17 -0
  206. data/lib/spree_core/testing_support/factories/product_factory.rb +16 -0
  207. data/lib/spree_core/testing_support/factories/product_group_factory.rb +3 -0
  208. data/lib/spree_core/testing_support/factories/product_option_type_factory.rb +4 -0
  209. data/lib/spree_core/testing_support/factories/product_property_factory.rb +4 -0
  210. data/lib/spree_core/testing_support/factories/product_scope_factory.rb +6 -0
  211. data/lib/spree_core/testing_support/factories/property_factory.rb +4 -0
  212. data/lib/spree_core/testing_support/factories/prototype_factory.rb +4 -0
  213. data/lib/spree_core/testing_support/factories/return_authorization_factory.rb +8 -0
  214. data/lib/spree_core/testing_support/factories/role_factory.rb +9 -0
  215. data/lib/spree_core/testing_support/factories/shipment_factory.rb +9 -0
  216. data/lib/spree_core/testing_support/factories/shipping_category_factory.rb +5 -0
  217. data/lib/spree_core/testing_support/factories/shipping_method_factory.rb +7 -0
  218. data/lib/spree_core/testing_support/factories/state_factory.rb +11 -0
  219. data/lib/spree_core/testing_support/factories/tax_category_factory.rb +8 -0
  220. data/lib/spree_core/testing_support/factories/tax_rate_factory.rb +5 -0
  221. data/lib/spree_core/testing_support/factories/taxon_factory.rb +5 -0
  222. data/lib/spree_core/testing_support/factories/taxonomy_factory.rb +3 -0
  223. data/lib/spree_core/testing_support/factories/tracker_factory.rb +5 -0
  224. data/lib/spree_core/testing_support/factories/user_factory.rb +15 -0
  225. data/lib/spree_core/testing_support/factories/variant_factory.rb +14 -0
  226. data/lib/spree_core/testing_support/factories/zone_factory.rb +18 -0
  227. data/lib/spree_core/theme_support/hook.rb +1 -1
  228. data/lib/spree_core/theme_support/more_patches.rb +20 -20
  229. data/lib/spree_core/version.rb +5 -0
  230. data/lib/tasks/common.rb +30 -0
  231. data/lib/tasks/install.rake +1 -1
  232. data/lib/tasks/rake_util.rb +19 -0
  233. data/lib/tasks/taxon.rake +14 -0
  234. data/public/images/reorder.jpg +0 -0
  235. data/public/javascripts/admin.js +0 -6
  236. data/public/javascripts/admin/unobtrusive_handlers.js +28 -0
  237. data/public/javascripts/checkout.js +3 -3
  238. data/public/stylesheets/admin/admin-forms.css +1 -6
  239. data/public/stylesheets/admin/admin.css +0 -28
  240. data/public/stylesheets/screen.css +0 -280
  241. metadata +81 -43
  242. data/app/controllers/countries_controller.rb +0 -11
  243. data/app/models/spree/alert.rb +0 -13
  244. data/app/models/state_monitor.rb +0 -25
  245. data/app/views/admin/shared/_alert.html.erb +0 -6
  246. data/app/views/countries/index.js.erb +0 -1
  247. data/app/views/shared/_doc_and_xmlns.html.erb +0 -2
  248. data/app/views/users/edit.html.erb +0 -9
  249. data/app/views/users/show.html.erb +0 -46
  250. data/lib/spree_core/validation_group.rb +0 -143
  251. data/public/stylesheets/scaffold.css +0 -54
@@ -1,4 +1,4 @@
1
- <h1><%= t("user_account") %></h1>
1
+ <h1><%= t("user_account") %></h1>
2
2
 
3
3
  <table>
4
4
  <tr>
@@ -6,7 +6,7 @@
6
6
  <td>
7
7
  <%= @user.email %>
8
8
  </td>
9
- </tr>
9
+ </tr>
10
10
  <tr>
11
11
  <th><%= t("roles") %></th>
12
12
  <td>
@@ -16,6 +16,6 @@
16
16
  </table>
17
17
 
18
18
  <p>
19
- <%= link_to_edit @user %> <%= t('or') %>
19
+ <%= link_to_edit @user, :class => 'edit_user' %> <%= t('or') %>
20
20
  <%= link_to t('back'), collection_url %>
21
21
  </p>
@@ -2,7 +2,7 @@
2
2
 
3
3
  <%= render :partial => 'admin/shared/product_tabs', :locals => {:current => "Variants"} %>
4
4
 
5
- <table class="index">
5
+ <table class="index sortable">
6
6
  <tr>
7
7
  <th><%= t("options") %></th>
8
8
  <th><%= t("price") %></th>
@@ -17,7 +17,7 @@
17
17
  <!-- you can skip variant with no options: that's just the default variant that all products have -->
18
18
  <% next if variant.option_values.empty? %>
19
19
  <tr id="<%= dom_id(variant) %>" <%= 'style="color:red;"' if variant.deleted? %>>
20
- <td><%= variant_options variant %></td>
20
+ <td><span class="handle"></span> <%= variant_options variant %></td>
21
21
  <td><%= variant.price %></td>
22
22
  <td><%= variant.sku %></td>
23
23
  <% Variant.additional_fields.select{|f| f[:only].nil? || f[:only].include?(:variant) }.each do |field| %>
@@ -37,15 +37,30 @@
37
37
  </table>
38
38
 
39
39
  <% if @product.options.empty? %>
40
- <p>
41
- <%= t("to_add_variants_you_must_first_define") %> <%= link_to t("option_types"), selected_admin_product_option_types_url(@product) %>
40
+
41
+ <p class='first_add_option_types'>
42
+ <%= t("to_add_variants_you_must_first_define") %>
43
+ <%= link_to t("option_types"), selected_admin_product_option_types_url(@product) %>
42
44
  </p>
45
+
43
46
  <% else %>
47
+
44
48
  <div id="new_variant"></div>
49
+
45
50
  <br/>
51
+
46
52
  <p id="new_var_link">
47
- <%= link_to icon('add') + ' ' + t("new_variant"), new_admin_product_variant_url(@product), :remote => :true, 'data-update' => 'new_variant', :class => 'iconlink' %>
48
- &nbsp;|&nbsp;<%= link_to @deleted.blank? ? t("show_deleted") : t("show_active"), admin_product_variants_url(@product, :deleted => @deleted.blank? ? "on" : "off") %>
53
+
54
+ <%= link_to icon('add') + ' ' + t("new_variant"), new_admin_product_variant_url(@product),
55
+ :remote => :true,
56
+ 'data-update' => 'new_variant',
57
+ :class => 'iconlink new' %>
58
+
59
+ &nbsp;|&nbsp;
60
+
61
+ <%= link_to @deleted.blank? ? t("show_deleted") : t("show_active"),
62
+ admin_product_variants_url(@product, :deleted => @deleted.blank? ? "on" : "off") %>
49
63
  </p>
64
+
50
65
  <%= image_tag "spinner.gif", :plugin=>"spree", :style => "display:none", :id => 'busy_indicator' %>
51
66
  <% end %>
@@ -1,29 +1,29 @@
1
- <% zone_form.field_container :name do %>
1
+ <%= zone_form.field_container :name do %>
2
2
  <%= zone_form.label :name, t("name") %><br />
3
3
  <%=zone_form.text_field :name %>
4
4
  <% end %>
5
5
 
6
- <% zone_form.field_container :description do %>
6
+ <%= zone_form.field_container :description do %>
7
7
  <%= zone_form.label :description, t("description") %><br />
8
8
  <%=zone_form.text_field :description %>
9
9
  <% end %>
10
10
 
11
11
  <p>
12
- <label><%= t("type") %></label><br />
12
+ <label><%= t("type") %></label><br />
13
13
  <label class="sub">
14
14
  <%= zone_form.radio_button("kind", "country", {:id => "country_based"}) %>
15
15
  <%= t("country_based") %>
16
- </label> &nbsp;
16
+ </label> &nbsp;
17
17
  <label class="sub">
18
18
  <%= zone_form.radio_button("kind", "state", {:id => "state_based"}) %>
19
19
  <%= t("state_based") %>
20
- </label> &nbsp;
21
- <label class="sub">
20
+ </label> &nbsp;
21
+ <label class="sub">
22
22
  <%= zone_form.radio_button("kind", "zone", {:id => "zone_based"}) %>
23
23
  <%= t("zone_based") %>
24
24
  </label>
25
25
  </p>
26
26
 
27
- <%= render "member_type", :type => "country", :zone_form => zone_form %>
28
- <%= render "member_type", :type => "state", :zone_form => zone_form %>
29
- <%= render "member_type", :type => "zone", :zone_form => zone_form %>
27
+ <%= render "member_type", :type => "country", :zone_form => zone_form %>
28
+ <%= render "member_type", :type => "state", :zone_form => zone_form %>
29
+ <%= render "member_type", :type => "zone", :zone_form => zone_form %>
@@ -4,12 +4,12 @@
4
4
  <fieldset id="">
5
5
  <legend><%= t(type) %></legend>
6
6
  <ul id="ul-nested-<%= type %>" class="member-list">
7
- <% zone_form.fields_for :zone_members do |member_form| %>
7
+ <%= zone_form.fields_for :zone_members do |member_form| %>
8
8
  <%= render "#{type}_member", :f => member_form %>
9
9
  <% end %>
10
10
  </ul>
11
- </fieldset>
12
- <p>
13
- <%= button_link_to t("add_#{type}"), "##{type}_member", {:icon => 'add', :id => "nested-#{type}"} %>
14
- </p>
11
+ <p>
12
+ <%= button_link_to t("add_#{type}"), "##{type}_member", {:icon => 'add', :id => "nested-#{type}"} %>
13
+ </p>
14
+ </fieldset>
15
15
  </div>
@@ -3,7 +3,7 @@
3
3
  <div class='toolbar'>
4
4
  <ul class='actions'>
5
5
  <li>
6
- <%= button_link_to t("new_zone"), new_object_url, :icon => 'add' %></p>
6
+ <%= button_link_to t("new_zone"), new_object_url, :icon => 'add', :id => 'admin_new_zone_link' %>
7
7
  </li>
8
8
  </ul>
9
9
  <br class='clear' />
@@ -11,11 +11,13 @@
11
11
 
12
12
 
13
13
  <h1><%= t("zones") %></h1>
14
- <table class="index">
14
+ <table class="index" id='listing_zones'>
15
15
  <thead>
16
16
  <tr>
17
- <th><%= order @search, :by => :name, :as => t("name") %></th>
18
- <th><%= order @search, :by => :description, :as => t("description") %></th>
17
+ <th><%= sort_link @search,:name, t("name"), :title => 'zones_order_by_name_title' %></th>
18
+ <th>
19
+ <%= sort_link @search,:description, t("description"), {}, {:title => 'zones_order_by_description_title'} %>
20
+ </th>
19
21
  <th></th>
20
22
  </tr>
21
23
  </thead>
@@ -25,7 +27,7 @@
25
27
  <td><%=zone.name %></td>
26
28
  <td><%=zone.description %></td>
27
29
  <td class="actions">
28
- <%=link_to_edit zone %> &nbsp;
30
+ <%=link_to_edit zone %> &nbsp;
29
31
  <%=link_to_delete zone %>
30
32
  </td>
31
33
  </tr>
@@ -61,7 +61,7 @@ div.inner input[type=text], div.inner select { width: 80%; }
61
61
  </p>
62
62
  <p id="bcountry" class="field">
63
63
  <%= bill_form.label :country_id, t(:country) %>
64
- <span id="bcountry"><%= bill_form.collection_select :country_id, Country.all, :id, :name, {}, {:class => 'required'} %></span>
64
+ <span id="bcountry"><%= bill_form.collection_select :country_id, available_countries, :id, :name, {}, {:class => 'required'} %></span>
65
65
  <span class="req">*</span>
66
66
  </p>
67
67
  <p id="bphone" class="field">
@@ -140,7 +140,7 @@ div.inner input[type=text], div.inner select { width: 80%; }
140
140
  </p>
141
141
  <p id="scountry" class="field">
142
142
  <%= ship_form.label :country_id, t(:country) %>
143
- <span id="scountry"><%= ship_form.collection_select :country_id, Country.all, :id, :name, {}, {:class => 'required'} %></span>
143
+ <span id="scountry"><%= ship_form.collection_select :country_id, available_countries, :id, :name, {}, {:class => 'required'} %></span>
144
144
  <span class="req">*</span>
145
145
  </p>
146
146
  <p id="sphone" class="field">
@@ -4,7 +4,7 @@
4
4
  <% @order.available_payment_methods.each do |method| %>
5
5
  <p>
6
6
  <label>
7
- <%= radio_button_tag "order[payments_attributes][][payment_method_id]", method.id, method == @order.payment_method %>
7
+ <%= radio_button_tag "order[payments_attributes][][payment_method_id]", method.id, method == @order.payment_method %>
8
8
  <%= t(method.name, :scope => :payment_methods, :default => method.name) %>
9
9
  </label>
10
10
  </p>
@@ -17,13 +17,10 @@
17
17
  <%= render "checkout/payment/#{method.method_type}", :payment_method => method %>
18
18
  </fieldset>
19
19
  </li>
20
- <% end %>
20
+ <% end %>
21
21
  </ul>
22
22
  <br style='clear:both;' />
23
- <p>
24
- <label><%= t(:coupon_code) %></label><br />
25
- <%= form.text_field :coupon_code, :size => 19 %>
26
- </p>
23
+ <%= hook :coupon_code_field, {:form => form} %>
27
24
  <% end %>
28
25
  </fieldset>
29
26
 
@@ -13,14 +13,9 @@
13
13
  <div id='wrapper'>
14
14
 
15
15
  <div id="header">
16
- <% if current_user %>
17
- <ul id="login-nav">
18
- <li><%= t('logged_in_as') %>: <%= current_user.email %></li>
19
- <li><%= link_to t('account'), edit_user_path(current_user) %></li>
20
- <li><%= link_to t('logout'), destroy_user_session_path %></li>
21
- <li><%= link_to t('store'), products_path %></li>
22
- </ul>
23
- <% end %>
16
+
17
+ <%= hook :admin_login_navigation_bar %>
18
+
24
19
  <a href="<%= admin_path %>"><%= image_tag Spree::Config[:admin_interface_logo], :id => 'logo' %></a>
25
20
  <h1><%= link_to t("administration"), admin_path %></h1>
26
21
  <div id="progress"><%= image_tag 'progress.gif' %> <%= t('loading') %>...</div>
@@ -50,7 +45,6 @@
50
45
  <div class="flash notice"><%= self.notice %></div>
51
46
  <% end %>
52
47
 
53
- <%= render :partial => 'admin/shared/alert', :collection => session[:alerts] %>
54
48
 
55
49
  <%= yield %>
56
50
 
@@ -1,4 +1,5 @@
1
- <%= render :partial => 'shared/doc_and_xmlns'%>
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2
+ <html xmlns="http://www.w3.org/1999/xhtml">
2
3
  <head>
3
4
  <%= hook :inside_head do %>
4
5
  <%= render :partial => 'shared/head'%>
@@ -34,7 +34,7 @@
34
34
  </td>
35
35
  <td>
36
36
  <%= hook :cart_item_delete, locals do %>
37
- <%= link_to(image_tag('/images/admin/icons/delete.png'), '#', :class => 'delete', :style => 'display:none') %>
37
+ <%= link_to(image_tag('/images/admin/icons/delete.png'), '#', :class => 'delete') %>
38
38
  <% end %>
39
39
  </td>
40
40
 
@@ -10,27 +10,28 @@
10
10
  <% end %>
11
11
 
12
12
  <% else %>
13
+ <%= hook :outside_cart_form do %>
14
+ <%= form_for(@order, :url => update_cart_path, :html=>{:id=>'updatecart'}) do |order_form| %>
15
+ <%= hook :inside_cart_form do %>
13
16
 
14
- <%= form_for(@order, :url => update_cart_path, :html=>{:id=>'updatecart'}) do |order_form| %>
15
- <%= hook :inside_cart_form do %>
17
+ <%= hook :cart_items do %>
18
+ <%= render :partial => 'form', :locals => {:order_form => order_form} %>
19
+ <% end %>
16
20
 
17
- <%= hook :cart_items do %>
18
- <%= render :partial => 'form', :locals => {:order_form => order_form} %>
19
- <% end %>
20
-
21
- <div id="subtotal">
22
- <h3><%= "#{t("subtotal")}: #{order_price(@order)}" %></h3>
23
- <div class="links">
24
- <%= link_to image_tag('/images/update.png') + t("update"), '#', :class => 'button checkout primary', :onclick => "$('form#updatecart').submit(); return false;" %>
25
- <%= link_to image_tag('/images/checkout.png') + t("checkout"), checkout_path, :class => 'button checkout primary' %>
26
- </div>
27
- </div>
21
+ <div id="subtotal">
22
+ <h3><%= "#{t("subtotal")}: #{order_price(@order)}" %></h3>
23
+ <div class="links">
24
+ <%= link_to image_tag('/images/update.png') + t("update"), '#', :class => 'button checkout primary', :onclick => "$('form#updatecart').submit(); return false;" %>
25
+ <%= link_to image_tag('/images/checkout.png') + t("checkout"), checkout_path, :class => 'button checkout primary' %>
26
+ </div>
27
+ </div>
28
28
 
29
- <p><%=link_to t("continue_shopping"), products_path, :class => 'button continue' %></p>
29
+ <p><%=link_to t("continue_shopping"), products_path, :class => 'button continue' %></p>
30
30
 
31
+ <% end %>
32
+ <% end %>
31
33
  <% end %>
32
- <% end %>
33
-
34
+
34
35
  <%= form_tag empty_cart_path, :method => :put do %>
35
36
  <p id="clear_cart_link">
36
37
  <input type="submit" value="<%= t('empty_cart') %>" class="button" />
@@ -5,7 +5,7 @@
5
5
  <br/><br/>
6
6
  <h3><%= t('thank_you_for_your_order') %></h3>
7
7
  <% else %>
8
- | <%= link_to t('my_account'), user_path(current_user) if current_user%>
8
+ | <%= link_to t('my_account'), account_path if current_user%>
9
9
  <% end %>
10
10
  <br/><br/>
11
11
 
@@ -15,7 +15,7 @@
15
15
  %>
16
16
  <% end %>
17
17
 
18
- <%= stylesheet_link_tag 'admin/admin-reset', 'admin/grids', 'admin/admin-typography', 'admin/admin-forms', 'admin/admin-tables', 'admin/admin', 'admin/autocomplete', 'admin/token-input', :cache => 'admin-all' %>
18
+ <%= stylesheet_link_tag 'admin/admin-reset', 'admin/grids', 'admin/admin-typography', 'admin/admin-forms', 'admin/admin-tables', 'admin/admin', 'admin/autocomplete', 'admin/token-input', :cache => 'admin/admin-all' %>
19
19
  <%= javascript_include_tag 'jquery-1.4.2.min.js', 'rails', 'jquery-ui', 'jquery.suggest', 'jquery.tokeninput.js', 'jquery.delayedobserver.js', :cache => 'jquery-admin-plugins' %>
20
20
  <%= javascript_include_tag('jquery.template') unless controller.controller_name == "overview" %>
21
21
  <%= javascript_include_tag 'admin', 'nested-attribute', 'zone', 'calculator', 'gateway' %>
@@ -1,7 +1,7 @@
1
1
  <% if target && target.errors.any? %>
2
2
  <div id="errorExplanation" class="errorExplanation">
3
- <h2><%= pluralize(target.errors.count, "error") %> prohibited this record from being saved:</h2>
4
- <p>There were problems with the following fields:</p>
3
+ <h2><%= t(:errors_prohibited_this_record_from_being_saved, :count => target.errors.count) %>:</h2>
4
+ <p><%= t(:there_were_problems_with_the_following_fields) %>:</p>
5
5
  <ul>
6
6
  <% target.errors.full_messages.each do |msg| %>
7
7
  <li><%= msg %></li>
@@ -1,4 +1,4 @@
1
- <%= form_tag '', :method => :get do %>
1
+ <%= form_tag '', :method => :get, :id => 'sidebar_products_search' do %>
2
2
  <% params[:search] ||= {} %>
3
3
  <input type="hidden" name="per_page" value="<%= params[:per_page] %>"/>
4
4
 
@@ -12,9 +12,9 @@
12
12
  <% labels.each do |nm,val| %>
13
13
  <% label = "#{filter[:name]}_#{nm}".gsub(/\s+/,'_') %>
14
14
  <li class="nowrap">
15
- <input type="checkbox"
16
- id="<%= label %>"
17
- name="search[<%= filter[:scope].to_s %>][]"
15
+ <input type="checkbox"
16
+ id="<%= label %>"
17
+ name="search[<%= filter[:scope].to_s %>][]"
18
18
  value="<%= val %>"
19
19
  <%= params[:search][filter[:scope]] && params[:search][filter[:scope]].include?(val.to_s) ? "checked" : "" %> />
20
20
  <label class="nowrap" for="<%= label %>"> <%= nm %> </label>
@@ -1,10 +1,10 @@
1
1
  <title><%= title %></title>
2
2
  <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
3
- <%= raw stylesheet_tags %>
3
+ <%== meta_data_tags %>
4
+ <%== stylesheet_tags %>
4
5
  <%= csrf_meta_tag %>
5
6
  <%= javascript_include_tag 'jquery-1.4.2.min', 'jquery.validate.min.js', 'rails', 'application', :cache => 'jquery-core' %>
6
7
  <% unless I18n.locale.to_s[0..1] == 'en' %>
7
8
  <%= javascript_include_tag ['localization/messages_', I18n.locale.to_s[0..1], '.js'].join %>
8
9
  <% end %>
9
10
  <%= yield :head %>
10
- <%= raw meta_data_tags %>
@@ -1,5 +1,5 @@
1
1
  <li><%= render 'shared/search' %></li>
2
- <%= render 'shared/login_bar' %>
2
+ <%= hook :shared_login_bar %>
3
3
  <% if store_menu? %>
4
4
  <%= render 'shared/store_menu' %>
5
- <% end %>
5
+ <% end %>
@@ -13,8 +13,10 @@
13
13
  <% products.each do |product| %>
14
14
  <% if Spree::Config[:show_zero_stock_products] || product.has_stock? %>
15
15
  <li id="product_<%= product.id %>">
16
- <%= link_to small_image(product), product %>
17
- <%= link_to raw(product.name + " <span class='price selling'>#{product_price(product)}</span>"), product, :class => 'info' %>
16
+ <%= hook :products_list_item, {:product => product} do %>
17
+ <%= link_to small_image(product), product %>
18
+ <%= link_to raw(product.name + " <span class='price selling'>#{product_price(product)}</span>"), product, :class => 'info' %>
19
+ <% end %>
18
20
  </li>
19
21
  <% end %>
20
22
  <% end %>
@@ -1,10 +1,17 @@
1
1
  <div id="taxonomies" class="sidebar-item">
2
- <% get_taxonomies.each do |taxonomy| %>
3
- <ul class="navigation-list">
4
- <li<%= ' class="current"' if @taxon && @taxon == taxonomy.root %>><%= link_to t("shop_by_taxonomy", :taxonomy => taxonomy.name.singularize), seo_url(taxonomy.root), :class => 'root' %></li>
5
- <% taxonomy.root.children.each do |taxon| %>
6
- <li<%= ' class="current"' if @taxon and ([@taxon] + @taxon.ancestors).include?(taxon) %>><%= link_to taxon.name, seo_url(taxon) %></li>
7
- <% end %>
8
- </ul>
9
- <% end %>
2
+ <% get_taxonomies.each do |taxonomy| %>
3
+ <ul class="navigation-list">
4
+ <li<%== ' class="current"' if @taxon && @taxon == taxonomy.root %>>
5
+ <%= link_to t("shop_by_taxonomy", :taxonomy => taxonomy.name.singularize), seo_url(taxonomy.root),
6
+ :class => 'root' %>
7
+ </li>
8
+
9
+ <% taxonomy.root.children.each do |taxon| %>
10
+ <li<%== ' class="current"' if @taxon and ([@taxon] + @taxon.ancestors).include?(taxon) %>>
11
+ <%= link_to taxon.name, seo_url(taxon) %>
12
+ </li>
13
+ <% end %>
14
+
15
+ </ul>
16
+ <% end %>
10
17
  </div>
@@ -6,10 +6,10 @@ Your order has been shipped
6
6
  Shipment Summary
7
7
  ============================================================
8
8
  <% for item in @shipment.line_items %>
9
- <%=item.variant.sku %> <%=item.variant.product.name%> <%= variant_options(item.variant) %> (<%=item.quantity%>) %>
9
+ <%=item.variant.sku %> <%=item.variant.product.name%> <%= variant_options(item.variant) %> (<%=item.quantity%>)
10
10
  <% end %>
11
11
  ============================================================
12
12
 
13
13
  <%= "Tracking Information: #{@shipment.tracking}" if @shipment.tracking %>
14
14
 
15
- Thank you for your business.
15
+ Thank you for your business.
@@ -0,0 +1,10 @@
1
+ <%
2
+ rerun = File.file?('rerun.txt') ? IO.read('rerun.txt') : ""
3
+ rerun_opts = rerun.to_s.strip.empty? ? "--format #{ENV['CUCUMBER_FORMAT'] || 'progress'} features" : "--format #{ENV['CUCUMBER_FORMAT'] || 'pretty'} #{rerun}"
4
+ std_opts = "--format #{ENV['CUCUMBER_FORMAT'] || 'progress'} --strict --tags ~@wip"
5
+ ci_opts = "--format progress --strict"
6
+ %>
7
+ default: <%= std_opts %> features
8
+ wip: --tags @wip:3 --wip features
9
+ ci: <%= ci_opts %> features CI=true
10
+ rerun: <%= rerun_opts %> --format rerun --out rerun.txt --strict --tags ~@wip