spree_frontend 3.0.0.rc1 → 3.0.0.rc3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/controllers/spree/orders_controller.rb +0 -1
- data/app/helpers/spree/frontend_helper.rb +1 -1
- data/app/views/kaminari/twitter-bootstrap-3/_first_page.html.erb +4 -4
- data/app/views/kaminari/twitter-bootstrap-3/_last_page.html.erb +3 -3
- data/app/views/kaminari/twitter-bootstrap-3/_next_page.html.erb +3 -3
- data/app/views/kaminari/twitter-bootstrap-3/_paginator.html.erb +17 -16
- data/app/views/kaminari/twitter-bootstrap-3/_prev_page.html.erb +3 -3
- data/app/views/spree/address/_form.html.erb +2 -1
- data/app/views/spree/checkout/_confirm.html.erb +1 -1
- data/app/views/spree/checkout/_delivery.html.erb +0 -3
- data/app/views/spree/checkout/_payment.html.erb +6 -7
- data/app/views/spree/checkout/edit.html.erb +1 -0
- data/app/views/spree/checkout/payment/_gateway.html.erb +0 -1
- data/app/views/spree/layouts/spree_application.html.erb +0 -2
- data/app/views/spree/orders/_line_item.html.erb +4 -3
- data/app/views/spree/orders/edit.html.erb +0 -3
- data/app/views/spree/orders/show.html.erb +1 -0
- data/app/views/spree/payments/_payment.html.erb +1 -0
- data/app/views/spree/products/_cart_form.html.erb +4 -6
- data/app/views/spree/products/_promotions.html.erb +6 -5
- data/app/views/spree/products/_taxons.html.erb +3 -5
- data/app/views/spree/products/index.html.erb +0 -4
- data/app/views/spree/products/show.html.erb +1 -8
- data/app/views/spree/shared/_error_messages.html.erb +3 -3
- data/app/views/spree/shared/_filters.html.erb +1 -0
- data/app/views/spree/shared/_google_checkout.js.erb +1 -1
- data/app/views/spree/shared/_header.html.erb +1 -3
- data/app/views/spree/shared/_nav_bar.html.erb +0 -1
- data/app/views/spree/shared/_order_details.html.erb +0 -3
- data/app/views/spree/shared/_products.html.erb +21 -21
- data/app/views/spree/shared/_search.html.erb +13 -12
- data/app/views/spree/shared/_shipment_tracking.html.erb +1 -0
- data/app/views/spree/shared/_taxonomies.html.erb +1 -0
- data/config/routes.rb +0 -1
- data/spec/controllers/controller_extension_spec.rb +13 -2
- data/spec/controllers/spree/checkout_controller_spec.rb +5 -4
- data/spec/controllers/spree/orders_controller_ability_spec.rb +22 -30
- data/spec/spec_helper.rb +1 -1
- metadata +6 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 21c4d3d6e5618eab61604b1b12a95fd8cdde9891
|
4
|
+
data.tar.gz: 148499f4d495b915912a7ce7cd5d41ef409a92ee
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 65bcce2469d7125984737b17d7a5367df1bb15eb1bedac13856f42492429923d94377510a5475a1fcc457681badbf2dd5d65c03bd5743daaa1e193deaa5a9227
|
7
|
+
data.tar.gz: ea10c019574ae8d23cc7e5c58b42f87899cb8a64f311d00a84e20c40fecf3efac36d682a34aa7fd30a31657ec1268a32a17a25996c7ee1448600c7c150205fe0
|
@@ -10,7 +10,7 @@ module Spree
|
|
10
10
|
separator = raw(separator)
|
11
11
|
crumbs = [content_tag(:li, content_tag(:span, link_to(Spree.t(:home), spree.root_path, itemprop: "url") + separator, itemprop: "title"), itemscope: "itemscope", itemtype: "http://data-vocabulary.org/Breadcrumb")]
|
12
12
|
if taxon
|
13
|
-
crumbs << content_tag(:li, content_tag(:span, link_to(Spree.t(:products), products_path, itemprop: "url") + separator, itemprop: "title"), itemscope: "itemscope", itemtype: "http://data-vocabulary.org/Breadcrumb")
|
13
|
+
crumbs << content_tag(:li, content_tag(:span, link_to(Spree.t(:products), spree.products_path, itemprop: "url") + separator, itemprop: "title"), itemscope: "itemscope", itemtype: "http://data-vocabulary.org/Breadcrumb")
|
14
14
|
crumbs << taxon.ancestors.collect { |ancestor| content_tag(:li, content_tag(:span, link_to(ancestor.name , seo_url(ancestor), itemprop: "url") + separator, itemprop: "title"), itemscope: "itemscope", itemtype: "http://data-vocabulary.org/Breadcrumb") } unless taxon.ancestors.empty?
|
15
15
|
crumbs << content_tag(:li, content_tag(:span, link_to(taxon.name , seo_url(taxon), itemprop: "url"), itemprop: "title"), class: 'active', itemscope: "itemscope", itemtype: "http://data-vocabulary.org/Breadcrumb")
|
16
16
|
else
|
@@ -7,7 +7,7 @@
|
|
7
7
|
remote: data-remote
|
8
8
|
-%>
|
9
9
|
<% unless current_page.first? %>
|
10
|
-
<li class="first">
|
11
|
-
|
12
|
-
</li>
|
13
|
-
<% end %>
|
10
|
+
<li class="first">
|
11
|
+
<%= link_to_unless current_page.first?, raw(t 'views.pagination.first'), url, :remote => remote %>
|
12
|
+
</li>
|
13
|
+
<% end %>
|
@@ -7,7 +7,7 @@
|
|
7
7
|
remote: data-remote
|
8
8
|
-%>
|
9
9
|
<% unless current_page.last? %>
|
10
|
-
<li class="last next"><%# "next" class present for border styling in twitter bootstrap %>
|
11
|
-
|
12
|
-
</li>
|
10
|
+
<li class="last next"><%# "next" class present for border styling in twitter bootstrap %>
|
11
|
+
<%= link_to_unless current_page.last?, raw(t 'views.pagination.last'), url, {:remote => remote} %>
|
12
|
+
</li>
|
13
13
|
<% end %>
|
@@ -7,7 +7,7 @@
|
|
7
7
|
remote: data-remote
|
8
8
|
-%>
|
9
9
|
<% unless current_page.last? %>
|
10
|
-
<li class="next_page">
|
11
|
-
|
12
|
-
</li>
|
10
|
+
<li class="next_page">
|
11
|
+
<%= link_to_unless current_page.last?, raw(t 'views.pagination.next'), url, :rel => 'next', :remote => remote %>
|
12
|
+
</li>
|
13
13
|
<% end %>
|
@@ -6,19 +6,20 @@
|
|
6
6
|
remote: data-remote
|
7
7
|
paginator: the paginator that renders the pagination tags inside
|
8
8
|
-%>
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
<%
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
9
|
+
<% pagination_class ||= '' %>
|
10
|
+
|
11
|
+
<%= paginator.render do %>
|
12
|
+
<ul class="pagination <%= pagination_class %>">
|
13
|
+
<%= first_page_tag unless current_page.first? %>
|
14
|
+
<%= prev_page_tag unless current_page.first? %>
|
15
|
+
<% each_page do |page| %>
|
16
|
+
<% if page.left_outer? || page.right_outer? || page.inside_window? %>
|
17
|
+
<%= page_tag page %>
|
18
|
+
<% elsif !page.was_truncated? %>
|
19
|
+
<%= gap_tag %>
|
20
|
+
<% end %>
|
21
|
+
<% end %>
|
22
|
+
<%= next_page_tag unless current_page.last? %>
|
23
|
+
<%= last_page_tag unless current_page.last? %>
|
24
|
+
</ul>
|
25
|
+
<% end %>
|
@@ -7,7 +7,7 @@
|
|
7
7
|
remote: data-remote
|
8
8
|
-%>
|
9
9
|
<% unless current_page.first? %>
|
10
|
-
<li class="prev">
|
11
|
-
|
12
|
-
</li>
|
10
|
+
<li class="prev">
|
11
|
+
<%= link_to_unless current_page.first?, raw(t 'views.pagination.previous'), url, :rel => 'prev', :remote => remote %>
|
12
|
+
</li>
|
13
13
|
<% end %>
|
@@ -1,4 +1,5 @@
|
|
1
1
|
<% address_id = address_type.chars.first %>
|
2
|
+
|
2
3
|
<div class="inner" data-hook=<%="#{address_type}_inner" %>>
|
3
4
|
<p class="form-group" id=<%="#{address_id}firstname" %>>
|
4
5
|
<%= form.label :firstname, Spree.t(:first_name) %><span class="required">*</span><br />
|
@@ -49,7 +50,7 @@
|
|
49
50
|
:disabled => have_states)
|
50
51
|
].join.gsub('"', "'").gsub("\n", "")
|
51
52
|
%>
|
52
|
-
<%= javascript_tag do
|
53
|
+
<%= javascript_tag do %>
|
53
54
|
$('#<%="#{address_id}state" %>').append("<%== state_elements %>");
|
54
55
|
<% end %>
|
55
56
|
</p>
|
@@ -3,7 +3,7 @@
|
|
3
3
|
<h3 class="panel-title"><%= Spree.t(:confirm) %></h3>
|
4
4
|
</div>
|
5
5
|
<div class="panel-body">
|
6
|
-
|
6
|
+
<%= render :partial => 'spree/shared/order_details', :locals => { :order => @order } %>
|
7
7
|
</div>
|
8
8
|
</div>
|
9
9
|
|
@@ -5,7 +5,6 @@
|
|
5
5
|
<div class="panel-body" data-hook="shipping_method_inner">
|
6
6
|
<div id="methods">
|
7
7
|
<%= form.fields_for :shipments do |ship_form| %>
|
8
|
-
|
9
8
|
<div class="shipment">
|
10
9
|
<h4 class="stock-location" data-hook="stock-location">
|
11
10
|
<%= Spree.t(:package_from) %>
|
@@ -52,7 +51,6 @@
|
|
52
51
|
<% end %>
|
53
52
|
</ul>
|
54
53
|
</div>
|
55
|
-
|
56
54
|
<% end %>
|
57
55
|
|
58
56
|
<% if @differentiator.try(:missing?) %>
|
@@ -86,7 +84,6 @@
|
|
86
84
|
</table>
|
87
85
|
</div>
|
88
86
|
<% end %>
|
89
|
-
|
90
87
|
</div>
|
91
88
|
<% if Spree::Config[:shipping_instructions] %>
|
92
89
|
<p id="minstrs" data-hook>
|
@@ -3,7 +3,6 @@
|
|
3
3
|
<h3 class="panel-title"><%= Spree.t(:payment_information) %></h3>
|
4
4
|
</div>
|
5
5
|
<div class="panel-body" data-hook="checkout_payment_step">
|
6
|
-
|
7
6
|
<% if @payment_sources.present? %>
|
8
7
|
<div class="card_options">
|
9
8
|
<%= radio_button_tag 'use_existing_card', 'yes', true %>
|
@@ -39,12 +38,12 @@
|
|
39
38
|
|
40
39
|
<ul class="list-group" id="payment-method-fields" data-hook>
|
41
40
|
<% @order.available_payment_methods.each do |method| %>
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
41
|
+
<li class="list-group-item">
|
42
|
+
<label>
|
43
|
+
<%= radio_button_tag "order[payments_attributes][][payment_method_id]", method.id, method == @order.available_payment_methods.first %>
|
44
|
+
<%= Spree.t(method.name, :scope => :payment_methods, :default => method.name) %>
|
45
|
+
</label>
|
46
|
+
</li>
|
48
47
|
<% end %>
|
49
48
|
</ul>
|
50
49
|
|
@@ -1,6 +1,7 @@
|
|
1
1
|
<% content_for :google_analytics do %>
|
2
2
|
<%= render partial: 'spree/shared/google_checkout.js', locals: { order: @order, step_number: (@order.checkout_steps.index(@order.state) + 1) } %>
|
3
3
|
<% end %>
|
4
|
+
|
4
5
|
<div id="checkout" data-hook>
|
5
6
|
<%= render partial: 'spree/shared/error_messages', locals: { target: @order } %>
|
6
7
|
|
@@ -1,5 +1,6 @@
|
|
1
|
-
<% variant = line_item.variant
|
2
|
-
|
1
|
+
<% variant = line_item.variant %>
|
2
|
+
|
3
|
+
<%= order_form.fields_for :line_items, line_item do |item_form| %>
|
3
4
|
<tr class="line-item">
|
4
5
|
<td class="cart-item-image" data-hook="cart_item_image">
|
5
6
|
<% if variant.images.length == 0 %>
|
@@ -33,4 +34,4 @@
|
|
33
34
|
<%= link_to content_tag(:span, '', class: 'glyphicon glyphicon-minus-sign'), '#', class: 'delete', id: "delete_#{dom_id(line_item)}" %>
|
34
35
|
</td>
|
35
36
|
</tr>
|
36
|
-
<% end
|
37
|
+
<% end %>
|
@@ -3,14 +3,11 @@
|
|
3
3
|
<h1><%= Spree.t(:shopping_cart) %></h1>
|
4
4
|
|
5
5
|
<% if @order.line_items.empty? %>
|
6
|
-
|
7
6
|
<div data-hook="empty_cart">
|
8
7
|
<div class="alert alert-info"><%= Spree.t(:your_cart_is_empty) %></div>
|
9
8
|
<p><%= link_to Spree.t(:continue_shopping), products_path, class: 'btn btn-default' %></p>
|
10
9
|
</div>
|
11
|
-
|
12
10
|
<% else %>
|
13
|
-
|
14
11
|
<div data-hook="outside_cart_form">
|
15
12
|
<%= form_for @order, url: update_cart_path, html: { id: 'update-cart' } do |order_form| %>
|
16
13
|
<div data-hook="inside_cart_form">
|
@@ -1,6 +1,5 @@
|
|
1
1
|
<%= form_for :order, :url => populate_orders_path do |f| %>
|
2
2
|
<div class="row" id="inside-product-cart-form" data-hook="inside_product_cart_form" itemprop="offers" itemscope itemtype="http://schema.org/Offer">
|
3
|
-
|
4
3
|
<% if @product.variants_and_option_values(current_currency).any? %>
|
5
4
|
<div id="product-variants" class="col-md-6">
|
6
5
|
<h3 class="product-section-title"><%= Spree.t(:variants) %></h3>
|
@@ -29,7 +28,6 @@
|
|
29
28
|
|
30
29
|
<% if @product.price_in(current_currency) and !@product.price.nil? %>
|
31
30
|
<div data-hook="product_price" class="col-md-5">
|
32
|
-
|
33
31
|
<div id="product-price">
|
34
32
|
<h6 class="product-section-title"><%= Spree.t(:price) %></h6>
|
35
33
|
<div>
|
@@ -60,10 +58,10 @@
|
|
60
58
|
</div>
|
61
59
|
</div>
|
62
60
|
<% else %>
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
61
|
+
<div id="product-price">
|
62
|
+
<br>
|
63
|
+
<div><span class="price selling" itemprop="price"><%= Spree.t('product_not_available_in_this_currency') %></span></div>
|
64
|
+
</div>
|
67
65
|
<% end %>
|
68
66
|
</div>
|
69
67
|
<% end %>
|
@@ -1,4 +1,5 @@
|
|
1
1
|
<% promotions = @product.possible_promotions %>
|
2
|
+
|
2
3
|
<% if promotions.any? %>
|
3
4
|
<div id="promotions">
|
4
5
|
<h3><%= Spree.t(:promotions) %></h3>
|
@@ -7,11 +8,11 @@
|
|
7
8
|
<h4><%= promotion.name %></h4>
|
8
9
|
<p><%= promotion.description %></p>
|
9
10
|
<% if promotion.products.any? %>
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
11
|
+
<ul>
|
12
|
+
<% promotion.products.each do |product| %>
|
13
|
+
<li><%= link_to product.name, product_path(product) %></li>
|
14
|
+
<% end %>
|
15
|
+
</ul>
|
15
16
|
<% end %>
|
16
17
|
</div>
|
17
18
|
<% end %>
|
@@ -1,14 +1,12 @@
|
|
1
1
|
<% if !@product.taxons.blank? %>
|
2
2
|
<div id="taxon-crumbs" data-hook class=" five ">
|
3
3
|
<h3 class="product-section-title"><%= Spree.t(:look_for_similar_items) %></h3>
|
4
|
-
|
5
4
|
<div data-hook="product_taxons">
|
6
5
|
<ul class="list-group" id="similar_items_by_taxon" data-hook>
|
7
|
-
|
8
|
-
|
9
|
-
|
6
|
+
<% @product.taxons.each do |taxon| %>
|
7
|
+
<li class="list-group-item"><%= link_to taxon.name, seo_url(taxon) %></li>
|
8
|
+
<% end %>
|
10
9
|
</ul>
|
11
10
|
</div>
|
12
|
-
|
13
11
|
</div>
|
14
12
|
<% end %>
|
@@ -10,9 +10,7 @@
|
|
10
10
|
<% end %>
|
11
11
|
<% end %>
|
12
12
|
|
13
|
-
|
14
13
|
<% if params[:keywords] %>
|
15
|
-
|
16
14
|
<div data-hook="search_results">
|
17
15
|
<% if @products.empty? %>
|
18
16
|
<h6 class="search-results-title"><%= Spree.t(:no_products_found) %></h6>
|
@@ -20,9 +18,7 @@
|
|
20
18
|
<%= render :partial => 'spree/shared/products', :locals => { :products => @products, :taxon => @taxon } %>
|
21
19
|
<% end %>
|
22
20
|
</div>
|
23
|
-
|
24
21
|
<% else %>
|
25
|
-
|
26
22
|
<div data-hook="homepage_products">
|
27
23
|
<% cache(cache_key_for_products) do %>
|
28
24
|
<%= render :partial => 'spree/shared/products', :locals => { :products => @products, :taxon => @taxon } %>
|
@@ -1,10 +1,9 @@
|
|
1
1
|
<% @body_id = 'product-details' %>
|
2
|
+
|
2
3
|
<% cache [I18n.locale, current_currency, @product] do %>
|
3
4
|
<div data-hook="product_show" itemscope itemtype="http://schema.org/Product">
|
4
|
-
|
5
5
|
<div class="col-md-4" data-hook="product_left_part">
|
6
6
|
<div data-hook="product_left_part_wrap">
|
7
|
-
|
8
7
|
<div id="product-images" data-hook="product_images">
|
9
8
|
<div id="main-image" class="panel panel-default" data-hook>
|
10
9
|
<div class="panel-body text-center">
|
@@ -23,15 +22,12 @@
|
|
23
22
|
<div data-hook="promotions">
|
24
23
|
<%= render :partial => 'promotions' %>
|
25
24
|
</div>
|
26
|
-
|
27
25
|
</div>
|
28
26
|
</div>
|
29
27
|
|
30
28
|
<div class="col-md-8" data-hook="product_right_part">
|
31
29
|
<div data-hook="product_right_part_wrap">
|
32
|
-
|
33
30
|
<div id="product-description" data-hook="product_description">
|
34
|
-
|
35
31
|
<h1 class="product-title" itemprop="name"><%= @product.name %></h1>
|
36
32
|
|
37
33
|
<div class="well" itemprop="description" data-hook="description">
|
@@ -41,13 +37,10 @@
|
|
41
37
|
<div id="cart-form" data-hook="cart_form">
|
42
38
|
<%= render :partial => 'cart_form' %>
|
43
39
|
</div>
|
44
|
-
|
45
40
|
</div>
|
46
41
|
|
47
42
|
<%= render :partial => 'taxons' %>
|
48
|
-
|
49
43
|
</div>
|
50
44
|
</div>
|
51
|
-
|
52
45
|
</div>
|
53
46
|
<% end %>
|
@@ -3,9 +3,9 @@
|
|
3
3
|
<h3><%= Spree.t(:errors_prohibited_this_record_from_being_saved, :count => target.errors.count) %>:</h3>
|
4
4
|
<p><%= Spree.t(:there_were_problems_with_the_following_fields) %>:</p>
|
5
5
|
<ul>
|
6
|
-
|
7
|
-
|
8
|
-
|
6
|
+
<% target.errors.full_messages.each do |msg| %>
|
7
|
+
<li><%= msg %></li>
|
8
|
+
<% end %>
|
9
9
|
</ul>
|
10
10
|
<br/>
|
11
11
|
</div>
|
@@ -1,7 +1,5 @@
|
|
1
1
|
<div class="row steps-data">
|
2
|
-
|
3
2
|
<% if order.has_step?("address") %>
|
4
|
-
|
5
3
|
<div class="col-md-3" data-hook="order-bill-address">
|
6
4
|
<h4><%= Spree.t(:billing_address) %> <%= link_to "(#{Spree.t(:edit)})", checkout_state_path(:address) unless order.completed? %></h4>
|
7
5
|
<%= render partial: 'spree/shared/address', locals: { address: order.bill_address } %>
|
@@ -36,7 +34,6 @@
|
|
36
34
|
<% end %>
|
37
35
|
</div>
|
38
36
|
</div>
|
39
|
-
|
40
37
|
</div>
|
41
38
|
|
42
39
|
<hr />
|
@@ -16,33 +16,33 @@
|
|
16
16
|
</div>
|
17
17
|
<% elsif params.key?(:keywords) %>
|
18
18
|
<div data-hook="products_search_results_heading_results_found">
|
19
|
-
<h6 class="search-results-title"><%= Spree.t(:search_results, :
|
19
|
+
<h6 class="search-results-title"><%= Spree.t(:search_results, keywords: h(params[:keywords])) %></h6>
|
20
20
|
</div>
|
21
21
|
<% end %>
|
22
22
|
</div>
|
23
23
|
|
24
24
|
<% if products.any? %>
|
25
|
-
<div id="products" class="row" data-hook>
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
25
|
+
<div id="products" class="row" data-hook>
|
26
|
+
<% products.each do |product| %>
|
27
|
+
<% url = spree.product_url(product, taxon_id: @taxon.try(:id)) %>
|
28
|
+
<div id="product_<%= product.id %>" class="col-md-3 col-sm-6 product-list-item" data-hook="products_list_item" itemscope itemtype="http://schema.org/Product">
|
29
|
+
<div class="panel panel-default">
|
30
|
+
<% cache(@taxon.present? ? [I18n.locale, current_currency, @taxon, product] : [I18n.locale, current_currency, product]) do %>
|
31
|
+
<div class="panel-body text-center product-body">
|
32
|
+
<%= link_to small_image(product, itemprop: "image"), url, itemprop: 'url' %><br/>
|
33
|
+
<%= link_to truncate(product.name, length: 50), url, class: 'info', itemprop: "name", title: product.name %>
|
34
|
+
</div>
|
35
|
+
<div class="panel-footer text-center">
|
36
|
+
<span itemprop="offers" itemscope itemtype="http://schema.org/Offer">
|
37
|
+
<span class="price selling lead" itemprop="price"><%= display_price(product) %></span>
|
38
|
+
</span>
|
39
|
+
</div>
|
40
|
+
<% end %>
|
41
|
+
</div>
|
41
42
|
</div>
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
</div>
|
43
|
+
<% end %>
|
44
|
+
<% reset_cycle("classes") %>
|
45
|
+
</div>
|
46
46
|
<% end %>
|
47
47
|
|
48
48
|
<% if paginated_products.respond_to?(:num_pages) %>
|
@@ -1,15 +1,16 @@
|
|
1
1
|
<% @taxons = @taxon && @taxon.parent ? @taxon.parent.children : Spree::Taxon.roots %>
|
2
|
+
|
2
3
|
<%= form_tag spree.products_path, :method => :get, class: "navbar-form" do %>
|
3
|
-
<div class="form-group">
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
</div>
|
11
|
-
<div class="form-group">
|
12
|
-
|
13
|
-
</div>
|
14
|
-
<%= submit_tag Spree.t(:search), :name => nil, class: "btn btn-success" %>
|
4
|
+
<div class="form-group">
|
5
|
+
<% cache(cache_key_for_taxons) do %>
|
6
|
+
<%= select_tag :taxon,
|
7
|
+
options_for_select([[Spree.t(:all_departments), '']] +
|
8
|
+
@taxons.map {|t| [t.name, t.id]},
|
9
|
+
@taxon ? @taxon.id : params[:taxon]), 'aria-label' => 'Taxon', class: "form-control" %>
|
10
|
+
<% end %>
|
11
|
+
</div>
|
12
|
+
<div class="form-group">
|
13
|
+
<%= search_field_tag :keywords, params[:keywords], :placeholder => Spree.t(:search), class: "form-control" %>
|
14
|
+
</div>
|
15
|
+
<%= submit_tag Spree.t(:search), :name => nil, class: "btn btn-success" %>
|
15
16
|
<% end %>
|
data/config/routes.rb
CHANGED
@@ -17,7 +17,6 @@ Spree::Core::Engine.add_routes do
|
|
17
17
|
end
|
18
18
|
|
19
19
|
get '/orders/populate', :to => populate_redirect
|
20
|
-
get '/orders/:id/token/:token' => 'orders#show', :as => :token_order
|
21
20
|
|
22
21
|
resources :orders, :except => [:index, :new, :create, :destroy] do
|
23
22
|
post :populate, :on => :collection
|
@@ -23,6 +23,15 @@ describe Spree::CustomController, :type => :controller do
|
|
23
23
|
Spree::CustomController.clear_overrides!
|
24
24
|
end
|
25
25
|
|
26
|
+
before do
|
27
|
+
@routes = ActionDispatch::Routing::RouteSet.new.tap do |r|
|
28
|
+
r.draw {
|
29
|
+
get 'index', to: 'spree/custom#index'
|
30
|
+
post 'create', to: 'spree/custom#create'
|
31
|
+
}
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
26
35
|
context "extension testing" do
|
27
36
|
context "index" do
|
28
37
|
context "specify symbol for handler instead of Proc" do
|
@@ -37,6 +46,7 @@ describe Spree::CustomController, :type => :controller do
|
|
37
46
|
end
|
38
47
|
end
|
39
48
|
end
|
49
|
+
|
40
50
|
describe "GET" do
|
41
51
|
it "has value success" do
|
42
52
|
spree_get :index
|
@@ -53,6 +63,7 @@ describe Spree::CustomController, :type => :controller do
|
|
53
63
|
respond_override({:index => {:html => {:failure => lambda { render(:text => 'failure!!!') }}}})
|
54
64
|
end
|
55
65
|
end
|
66
|
+
|
56
67
|
describe "GET" do
|
57
68
|
it "has value success" do
|
58
69
|
spree_get :index
|
@@ -69,6 +80,7 @@ describe Spree::CustomController, :type => :controller do
|
|
69
80
|
respond_override({:index => {:html => {:failure => lambda { render(:text => 'failure!!!') }}}})
|
70
81
|
end
|
71
82
|
end
|
83
|
+
|
72
84
|
describe "GET" do
|
73
85
|
it "has value success" do
|
74
86
|
spree_get :index
|
@@ -101,6 +113,7 @@ describe Spree::CustomController, :type => :controller do
|
|
101
113
|
respond_override({:index => {:html => {:success => lambda { render(:text => 'success!!!') }}}})
|
102
114
|
end
|
103
115
|
end
|
116
|
+
|
104
117
|
describe "POST" do
|
105
118
|
it "should not effect the wrong controller" do
|
106
119
|
spree_get :index
|
@@ -108,8 +121,6 @@ describe Spree::CustomController, :type => :controller do
|
|
108
121
|
end
|
109
122
|
end
|
110
123
|
end
|
111
|
-
|
112
124
|
end
|
113
125
|
end
|
114
|
-
|
115
126
|
end
|
@@ -318,7 +318,8 @@ describe Spree::CheckoutController, :type => :controller do
|
|
318
318
|
it "due to no available shipping rates for any of the shipments" do
|
319
319
|
expect(order.shipments.count).to eq(1)
|
320
320
|
order.shipments.first.shipping_rates.delete_all
|
321
|
-
|
321
|
+
|
322
|
+
spree_put :update, state: order.state, :order => {}
|
322
323
|
expect(flash[:error]).to eq(Spree.t(:items_cannot_be_shipped))
|
323
324
|
expect(response).to redirect_to(spree.checkout_state_path('address'))
|
324
325
|
end
|
@@ -332,7 +333,7 @@ describe Spree::CheckoutController, :type => :controller do
|
|
332
333
|
end
|
333
334
|
|
334
335
|
it "due to the order having errors" do
|
335
|
-
spree_put :update, :order => {}
|
336
|
+
spree_put :update, state: order.state, :order => {}
|
336
337
|
expect(flash[:error]).to eq("Base error\nAdjustments error")
|
337
338
|
expect(response).to redirect_to(spree.checkout_state_path('address'))
|
338
339
|
end
|
@@ -359,7 +360,7 @@ describe Spree::CheckoutController, :type => :controller do
|
|
359
360
|
|
360
361
|
it "when GatewayError is raised" do
|
361
362
|
allow_any_instance_of(Spree::Payment).to receive(:process!).and_raise(Spree::Core::GatewayError.new(Spree.t(:payment_processing_failed)))
|
362
|
-
spree_put :update, :order => {}
|
363
|
+
spree_put :update, state: order.state, :order => {}
|
363
364
|
expect(flash[:error]).to eq(Spree.t(:payment_processing_failed))
|
364
365
|
end
|
365
366
|
end
|
@@ -403,7 +404,7 @@ describe Spree::CheckoutController, :type => :controller do
|
|
403
404
|
|
404
405
|
it "doesn't set shipping address on the order" do
|
405
406
|
expect(order).to_not receive(:ship_address=)
|
406
|
-
spree_post :update
|
407
|
+
spree_post :update, state: order.state
|
407
408
|
end
|
408
409
|
|
409
410
|
it "doesn't remove unshippable items before payment" do
|
@@ -1,45 +1,40 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
module Spree
|
4
|
-
describe OrdersController, :
|
5
|
-
ORDER_TOKEN = 'ORDER_TOKEN'
|
6
|
-
|
4
|
+
describe OrdersController, type: :controller do
|
7
5
|
let(:user) { create(:user) }
|
8
6
|
let(:guest_user) { create(:user) }
|
9
7
|
let(:order) { Spree::Order.create }
|
10
8
|
|
11
|
-
it 'should understand order routes with token' do
|
12
|
-
expect(spree.token_order_path('R123456', 'ABCDEF')).to eq('/orders/R123456/token/ABCDEF')
|
13
|
-
end
|
14
|
-
|
15
9
|
context 'when an order exists in the cookies.signed' do
|
16
10
|
let(:token) { 'some_token' }
|
17
11
|
let(:specified_order) { create(:order) }
|
18
12
|
|
19
13
|
before do
|
20
|
-
|
21
|
-
allow(controller).to receive_messages :
|
14
|
+
cookies.signed[:guest_token] = token
|
15
|
+
allow(controller).to receive_messages current_order: order
|
16
|
+
allow(controller).to receive_messages spree_current_user: user
|
22
17
|
end
|
23
18
|
|
24
19
|
context '#populate' do
|
25
20
|
it 'should check if user is authorized for :edit' do
|
26
21
|
expect(controller).to receive(:authorize!).with(:edit, order, token)
|
27
|
-
spree_post :populate
|
22
|
+
spree_post :populate
|
28
23
|
end
|
29
24
|
it "should check against the specified order" do
|
30
25
|
expect(controller).to receive(:authorize!).with(:edit, specified_order, token)
|
31
|
-
spree_post :populate, :
|
26
|
+
spree_post :populate, id: specified_order.number
|
32
27
|
end
|
33
28
|
end
|
34
29
|
|
35
30
|
context '#edit' do
|
36
31
|
it 'should check if user is authorized for :edit' do
|
37
32
|
expect(controller).to receive(:authorize!).with(:edit, order, token)
|
38
|
-
spree_get :edit
|
33
|
+
spree_get :edit
|
39
34
|
end
|
40
35
|
it "should check against the specified order" do
|
41
36
|
expect(controller).to receive(:authorize!).with(:edit, specified_order, token)
|
42
|
-
spree_get :edit, :
|
37
|
+
spree_get :edit, id: specified_order.number
|
43
38
|
end
|
44
39
|
end
|
45
40
|
|
@@ -47,54 +42,51 @@ module Spree
|
|
47
42
|
it 'should check if user is authorized for :edit' do
|
48
43
|
allow(order).to receive :update_attributes
|
49
44
|
expect(controller).to receive(:authorize!).with(:edit, order, token)
|
50
|
-
spree_post :update, :
|
45
|
+
spree_post :update, order: { email: "foo@bar.com" }
|
51
46
|
end
|
52
47
|
it "should check against the specified order" do
|
53
48
|
allow(order).to receive :update_attributes
|
54
49
|
expect(controller).to receive(:authorize!).with(:edit, specified_order, token)
|
55
|
-
spree_post :update, :
|
50
|
+
spree_post :update, order: { email: "foo@bar.com" }, id: specified_order.number
|
56
51
|
end
|
57
52
|
end
|
58
53
|
|
59
54
|
context '#empty' do
|
60
55
|
it 'should check if user is authorized for :edit' do
|
61
56
|
expect(controller).to receive(:authorize!).with(:edit, order, token)
|
62
|
-
spree_post :empty
|
57
|
+
spree_post :empty
|
63
58
|
end
|
64
59
|
it "should check against the specified order" do
|
65
60
|
expect(controller).to receive(:authorize!).with(:edit, specified_order, token)
|
66
|
-
spree_post :empty, :
|
61
|
+
spree_post :empty, id: specified_order.number
|
67
62
|
end
|
68
63
|
end
|
69
64
|
|
70
65
|
context "#show" do
|
71
66
|
it "should check against the specified order" do
|
72
67
|
expect(controller).to receive(:authorize!).with(:edit, specified_order, token)
|
73
|
-
spree_get :show, :
|
68
|
+
spree_get :show, id: specified_order.number
|
74
69
|
end
|
75
70
|
end
|
76
71
|
end
|
77
72
|
|
78
73
|
context 'when no authenticated user' do
|
79
|
-
let(:order) { create(:order, :
|
74
|
+
let(:order) { create(:order, number: 'R123') }
|
80
75
|
|
81
76
|
context '#show' do
|
82
|
-
context 'when
|
83
|
-
|
84
|
-
cookies.signed[:guest_token] = "soo wrong"
|
85
|
-
spree_get :show, { :id => 'R123', :token => order.guest_token }
|
86
|
-
expect(cookies.signed[:guest_token]).to eq(order.guest_token)
|
87
|
-
end
|
77
|
+
context 'when guest_token correct' do
|
78
|
+
before { cookies.signed[:guest_token] = order.guest_token }
|
88
79
|
|
89
|
-
it '
|
90
|
-
|
91
|
-
|
80
|
+
it 'displays the page' do
|
81
|
+
expect(controller).to receive(:authorize!).with(:edit, order, order.guest_token)
|
82
|
+
spree_get :show, { id: 'R123' }
|
83
|
+
expect(response.code).to eq('200')
|
92
84
|
end
|
93
85
|
end
|
94
86
|
|
95
|
-
context 'when
|
87
|
+
context 'when guest_token not present' do
|
96
88
|
it 'should respond with 404' do
|
97
|
-
spree_get :show, {:
|
89
|
+
spree_get :show, { id: 'R123'}
|
98
90
|
expect(response.code).to eq('404')
|
99
91
|
end
|
100
92
|
end
|
data/spec/spec_helper.rb
CHANGED
@@ -108,7 +108,7 @@ RSpec.configure do |config|
|
|
108
108
|
|
109
109
|
config.include Spree::TestingSupport::Preferences
|
110
110
|
config.include Spree::TestingSupport::UrlHelpers
|
111
|
-
config.include Spree::TestingSupport::ControllerRequests
|
111
|
+
config.include Spree::TestingSupport::ControllerRequests, type: :controller
|
112
112
|
config.include Spree::TestingSupport::Flash
|
113
113
|
|
114
114
|
config.include Paperclip::Shoulda::Matchers
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: spree_frontend
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.0.0.
|
4
|
+
version: 3.0.0.rc3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Sean Schofield
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2015-02-
|
11
|
+
date: 2015-02-23 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: spree_api
|
@@ -16,28 +16,28 @@ dependencies:
|
|
16
16
|
requirements:
|
17
17
|
- - '='
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: 3.0.0.
|
19
|
+
version: 3.0.0.rc3
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
24
|
- - '='
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version: 3.0.0.
|
26
|
+
version: 3.0.0.rc3
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: spree_core
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
31
|
- - '='
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version: 3.0.0.
|
33
|
+
version: 3.0.0.rc3
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
38
|
- - '='
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version: 3.0.0.
|
40
|
+
version: 3.0.0.rc3
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: bootstrap-sass
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|