spree_frontend 3.7.14.1 → 4.0.0.beta
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +1 -1
- data/app/assets/javascripts/spree/frontend/checkout/address.js +42 -14
- data/app/assets/javascripts/spree/frontend/checkout/address_book.js +56 -0
- data/app/assets/javascripts/spree/frontend/product.js +54 -39
- data/app/assets/javascripts/spree/frontend.js +4 -1
- data/app/assets/stylesheets/spree/frontend/_variables.scss +1 -1
- data/app/assets/stylesheets/spree/frontend/address_book.scss +8 -0
- data/app/assets/stylesheets/spree/frontend/frontend_bootstrap.css.scss +13 -35
- data/app/assets/stylesheets/spree/frontend.css +1 -0
- data/app/controllers/concerns/spree/checkout/address_book.rb +53 -0
- data/app/controllers/spree/addresses_controller.rb +72 -0
- data/app/controllers/spree/checkout_controller.rb +2 -0
- data/app/controllers/spree/orders_controller.rb +0 -55
- data/app/controllers/spree/products_controller.rb +5 -1
- data/app/controllers/spree/store_controller.rb +1 -1
- data/app/helpers/spree/addresses_helper.rb +36 -0
- data/app/helpers/spree/frontend_helper.rb +16 -15
- data/app/views/kaminari/{twitter-bootstrap-3 → twitter-bootstrap-4}/_first_page.html.erb +2 -2
- data/app/views/kaminari/{twitter-bootstrap-3 → twitter-bootstrap-4}/_gap.html.erb +5 -1
- data/app/views/kaminari/{twitter-bootstrap-3 → twitter-bootstrap-4}/_last_page.html.erb +2 -2
- data/app/views/kaminari/{twitter-bootstrap-3 → twitter-bootstrap-4}/_next_page.html.erb +2 -2
- data/app/views/kaminari/{twitter-bootstrap-3 → twitter-bootstrap-4}/_page.html.erb +8 -2
- data/app/views/kaminari/{twitter-bootstrap-3 → twitter-bootstrap-4}/_paginator.html.erb +1 -1
- data/app/views/kaminari/{twitter-bootstrap-3 → twitter-bootstrap-4}/_prev_page.html.erb +2 -2
- data/app/views/spree/address/_form.html.erb +27 -24
- data/app/views/spree/addresses/_form.html.erb +18 -0
- data/app/views/spree/addresses/destroy.js.erb +2 -0
- data/app/views/spree/addresses/edit.html.erb +23 -0
- data/app/views/spree/addresses/new.html.erb +23 -0
- data/app/views/spree/checkout/_address.html.erb +61 -37
- data/app/views/spree/checkout/_confirm.html.erb +12 -10
- data/app/views/spree/checkout/_delivery.html.erb +27 -15
- data/app/views/spree/checkout/_payment.html.erb +14 -9
- data/app/views/spree/checkout/_summary.html.erb +59 -57
- data/app/views/spree/checkout/edit.html.erb +6 -6
- data/app/views/spree/checkout/payment/_gateway.html.erb +43 -35
- data/app/views/spree/layouts/spree_application.html.erb +5 -2
- data/app/views/spree/orders/_form.html.erb +38 -25
- data/app/views/spree/orders/edit.html.erb +28 -22
- data/app/views/spree/orders/show.html.erb +2 -1
- data/app/views/spree/products/_cart_form.html.erb +28 -26
- data/app/views/spree/products/_product.html.erb +7 -8
- data/app/views/spree/products/_promotions.html.erb +13 -11
- data/app/views/spree/products/_properties.html.erb +10 -3
- data/app/views/spree/products/_thumbnails.html.erb +5 -7
- data/app/views/spree/products/show.html.erb +8 -8
- data/app/views/spree/shared/_filters.html.erb +29 -9
- data/app/views/spree/shared/_header.html.erb +2 -2
- data/app/views/spree/shared/_login_bar.html.erb +9 -3
- data/app/views/spree/shared/_main_nav_bar.html.erb +15 -15
- data/app/views/spree/shared/_nav_bar.html.erb +2 -2
- data/app/views/spree/shared/_order_details.html.erb +143 -89
- data/app/views/spree/shared/_products.html.erb +2 -2
- data/app/views/spree/shared/_search.html.erb +19 -12
- data/app/views/spree/shared/_sidebar.html.erb +1 -1
- data/app/views/spree/shared/_taxonomies.html.erb +7 -3
- data/config/routes.rb +2 -0
- data/lib/spree/frontend/engine.rb +4 -0
- data/lib/spree/frontend.rb +3 -3
- data/spree_frontend.gemspec +4 -3
- metadata +48 -25
@@ -1,27 +1,30 @@
|
|
1
1
|
<%= form_for :order, html: { id: 'add-to-cart-form' } do |f| %>
|
2
2
|
<div class="row" id="inside-product-cart-form" data-hook="inside_product_cart_form" itemprop="offers" itemscope itemtype="https://schema.org/Offer">
|
3
3
|
<% if @product.variants_and_option_values(current_currency).any? %>
|
4
|
-
<div id="product-variants" class="col-
|
4
|
+
<div id="product-variants" class="col-lg-6 mt-4">
|
5
5
|
<h3 class="product-section-title"><%= Spree.t(:variants) %></h3>
|
6
6
|
<ul class="list-group">
|
7
7
|
<% @product.variants_and_option_values(current_currency).each_with_index do |variant, index| %>
|
8
|
-
<li>
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
8
|
+
<li class="list-group-item <%= "active" if index == 0 %>">
|
9
|
+
<div class="form-check">
|
10
|
+
<%= radio_button_tag "variant_id", variant.id, index == 0,
|
11
|
+
'data-price' => variant.price_in(current_currency).money,
|
12
|
+
'data-in-stock' => variant.can_supply?,
|
13
|
+
'data-backordered' => variant.backordered?,
|
14
|
+
class: 'form-check-input'
|
15
|
+
%>
|
16
|
+
<%= label_tag "variant_id_#{ variant.id }", class: "form-check-label" do %>
|
17
|
+
<span class="variant-description">
|
18
|
+
<%= variant.options_text %>
|
19
|
+
</span>
|
20
|
+
<% if variant_price variant %>
|
21
|
+
<span class="price diff"><%= variant_price variant %></span>
|
22
|
+
<% end %>
|
23
|
+
<% unless variant.can_supply? %>
|
24
|
+
<span class="out-of-stock"><%= Spree.t(:out_of_stock) %></span>
|
25
|
+
<% end %>
|
20
26
|
<% end %>
|
21
|
-
|
22
|
-
<span class="out-of-stock"><%= Spree.t(:out_of_stock) %></span>
|
23
|
-
<% end %>
|
24
|
-
<% end %>
|
27
|
+
</div>
|
25
28
|
</li>
|
26
29
|
<% end%>
|
27
30
|
</ul>
|
@@ -31,9 +34,9 @@
|
|
31
34
|
<% end %>
|
32
35
|
|
33
36
|
<% if @product.price_in(current_currency) && !@product.price.nil? %>
|
34
|
-
<div data-hook="product_price" class="col-
|
37
|
+
<div data-hook="product_price" class="col-lg-5 mt-4">
|
35
38
|
<div id="product-price">
|
36
|
-
<
|
39
|
+
<h3 class="product-section-title"><%= Spree.t(:price) %></h3>
|
37
40
|
<div>
|
38
41
|
<span class="lead price selling" itemprop="price" content="<%= @product.price_in(current_currency).amount.to_d %>">
|
39
42
|
<%= display_price(@product) %>
|
@@ -44,8 +47,9 @@
|
|
44
47
|
<% if @product.master.can_supply? %>
|
45
48
|
<link itemprop="availability" href="https://schema.org/InStock" />
|
46
49
|
<% elsif @product.variants.empty? %>
|
47
|
-
<
|
48
|
-
|
50
|
+
<span class="out-of-stock d-block mt-2">
|
51
|
+
<%= Spree.t(:out_of_stock) %>
|
52
|
+
</span>
|
49
53
|
<% end %>
|
50
54
|
<% if @product.backordered? %>
|
51
55
|
<div class="alert alert-warning" id="cart-backordered-info">
|
@@ -55,22 +59,20 @@
|
|
55
59
|
</div>
|
56
60
|
|
57
61
|
<% if @product.can_supply? %>
|
58
|
-
<div class="add-to-cart">
|
59
|
-
<br />
|
62
|
+
<div class="add-to-cart mt-2">
|
60
63
|
<div class="input-group">
|
61
64
|
<%= number_field_tag :quantity, 1, class: 'title form-control', min: 1 %>
|
62
|
-
<
|
65
|
+
<div class="input-group-append">
|
63
66
|
<%= button_tag class: 'btn btn-success', id: 'add-to-cart-button', type: :submit, disabled: true do %>
|
64
67
|
<%= Spree.t(:add_to_cart) %>
|
65
68
|
<% end %>
|
66
|
-
</
|
69
|
+
</div>
|
67
70
|
</div>
|
68
71
|
</div>
|
69
72
|
<% end %>
|
70
73
|
</div>
|
71
74
|
<% else %>
|
72
75
|
<div id="product-price">
|
73
|
-
<br />
|
74
76
|
<div>
|
75
77
|
<span class="price selling" itemprop="price">
|
76
78
|
<%= Spree.t('product_not_available_in_this_currency') %>
|
@@ -1,15 +1,14 @@
|
|
1
1
|
<% url = spree.product_path(product, taxon_id: taxon.try(:id)) %>
|
2
|
-
<div id="product_<%= product.id %>" class="
|
3
|
-
<div class="
|
2
|
+
<div id="product_<%= product.id %>" class="d-flex w-100 col-12 col-sm-6 col-lg-4 col-xl-3 product-list-item mb-4" data-hook="products_list_item" itemscope itemtype="https://schema.org/Product">
|
3
|
+
<div class="card w-100">
|
4
4
|
<% cache(taxon.present? ? [I18n.locale, current_currency, taxon, product] : cache_key_for_product(product)) do %>
|
5
|
-
<div class="
|
6
|
-
<%= link_to url, itemprop: "url" do %>
|
7
|
-
<%= small_image(product, itemprop: "image")
|
8
|
-
<%= content_tag(:span, truncate(product.name, length: 50), class: 'info', itemprop: "name", title: product.name) %>
|
5
|
+
<div class="card-body text-center product-body">
|
6
|
+
<%= link_to url, itemprop: "url", class: 'd-block text-center' do %>
|
7
|
+
<%= small_image(product, itemprop: "image", class: "d-block mx-auto") %>
|
8
|
+
<%= content_tag(:span, truncate(product.name, length: 50), class: 'info mt-3 d-block', itemprop: "name", title: product.name) %>
|
9
9
|
<% end %>
|
10
|
-
<br/>
|
11
10
|
</div>
|
12
|
-
<div class="
|
11
|
+
<div class="card-footer text-center">
|
13
12
|
<span itemprop="offers" itemscope itemtype="https://schema.org/Offer">
|
14
13
|
<span class="price selling lead" itemprop="price" content="<%= (product.price_in(current_currency).amount.nil?)? 0 : product.price_in(current_currency).amount.to_d %>">
|
15
14
|
<%= display_price(product) %>
|
@@ -4,17 +4,19 @@
|
|
4
4
|
<div id="promotions">
|
5
5
|
<h3><%= Spree.t(:promotions) %></h3>
|
6
6
|
<% promotions.each do |promotion| %>
|
7
|
-
<div class="
|
8
|
-
<
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
7
|
+
<div class="card mb-3 bg-light">
|
8
|
+
<div class="card-body p-1">
|
9
|
+
<h4><%= promotion.name %></h4>
|
10
|
+
<p><%= promotion.description %></p>
|
11
|
+
<% if promotion.products.any? %>
|
12
|
+
<ul>
|
13
|
+
<% promotion.products.each do |product| %>
|
14
|
+
<li><%= link_to product.name, product_path(product) %></li>
|
15
|
+
<% end %>
|
16
|
+
</ul>
|
17
|
+
<% end %>
|
18
|
+
</div>
|
19
|
+
</div>
|
18
20
|
<% end %>
|
19
21
|
</div>
|
20
22
|
<% end %>
|
@@ -1,11 +1,18 @@
|
|
1
|
-
<% unless @product_properties.blank? %>
|
2
|
-
<h3 class="product-section-title"
|
1
|
+
<% unless @product_properties.blank? %>
|
2
|
+
<h3 class="product-section-title h4 mt-4">
|
3
|
+
<%= Spree.t('properties')%>
|
4
|
+
</h3>
|
5
|
+
|
3
6
|
<table id="product-properties" class="table table-striped" data-hook>
|
4
7
|
<tbody>
|
5
8
|
<% @product_properties.each do |product_property| %>
|
6
9
|
<% css_class = cycle('even', 'odd', name: "properties") %>
|
7
10
|
<tr class="<%= css_class %>">
|
8
|
-
<td
|
11
|
+
<td>
|
12
|
+
<strong>
|
13
|
+
<%= product_property.property.presentation %>
|
14
|
+
</strong>
|
15
|
+
</td>
|
9
16
|
<td><%= product_property.value %></td>
|
10
17
|
</tr>
|
11
18
|
<% end %>
|
@@ -1,19 +1,17 @@
|
|
1
1
|
<%# no need for thumbnails unless there is more than one image %>
|
2
2
|
<% if (@product.images + @product.variant_images).uniq.size > 1 %>
|
3
|
-
<ul id="product-thumbnails" class="thumbnails
|
3
|
+
<ul id="product-thumbnails" class="thumbnails d-flex w-100 pl-0 my-4" data-hook>
|
4
4
|
<% @product.images.each do |i| %>
|
5
|
-
<li class='tmb-all tmb-<%= i.viewable.id %>'>
|
6
|
-
|
7
|
-
<%= link_to(img_tag, main_app.url_for(i.url(:product))) %>
|
5
|
+
<li class='tmb-all mr-2 tmb-<%= i.viewable.id %>'>
|
6
|
+
<%= link_to(image_tag(main_app.url_for(i.url(:mini)), class: "img-thumbnail d-inline-block"), main_app.url_for(i.url(:product))) %>
|
8
7
|
</li>
|
9
8
|
<% end %>
|
10
9
|
|
11
10
|
<% if @product.has_variants? %>
|
12
11
|
<% @product.variant_images.each do |i| %>
|
13
12
|
<% next if @product.images.include?(i) %>
|
14
|
-
<li class='vtmb tmb-<%= i.viewable.id %>'>
|
15
|
-
|
16
|
-
<%= link_to(img_tag, main_app.url_for(i.url(:product))) %>
|
13
|
+
<li class='vtmb mr-2 tmb-<%= i.viewable.id %>'>
|
14
|
+
<%= link_to(image_tag(main_app.url_for(i.url(:mini)), class: "img-thumbnail"), main_app.url_for(i.url(:product))) %>
|
17
15
|
</li>
|
18
16
|
<% end %>
|
19
17
|
<% end %>
|
@@ -2,11 +2,11 @@
|
|
2
2
|
|
3
3
|
<% cache cache_key_for_product do %>
|
4
4
|
<div data-hook="product_show" class="row" itemscope itemtype="https://schema.org/Product">
|
5
|
-
<div class="col-
|
5
|
+
<div class="col-lg-4 col-md-5" data-hook="product_left_part">
|
6
6
|
<div data-hook="product_left_part_wrap">
|
7
7
|
<div id="product-images" data-hook="product_images">
|
8
|
-
<div id="main-image" class="
|
9
|
-
<div class="
|
8
|
+
<div id="main-image" class="card " data-hook>
|
9
|
+
<div class="card-body text-center">
|
10
10
|
<%= product_image(@product, itemprop: "image") %>
|
11
11
|
</div>
|
12
12
|
</div>
|
@@ -25,13 +25,13 @@
|
|
25
25
|
</div>
|
26
26
|
</div>
|
27
27
|
|
28
|
-
<div class="col-
|
28
|
+
<div class="col-lg-8 col-md-7" data-hook="product_right_part">
|
29
29
|
<div data-hook="product_right_part_wrap">
|
30
30
|
<div id="product-description" data-hook="product_description">
|
31
|
-
<h1 class="product-title" itemprop="name"><%= @product.name %></h1>
|
31
|
+
<h1 class="product-title mt-2" itemprop="name"><%= @product.name %></h1>
|
32
32
|
|
33
|
-
<div
|
34
|
-
<%= product_description(@product) %>
|
33
|
+
<div itemprop="description" data-hook="description">
|
34
|
+
<%= sanitize product_description(@product) %>
|
35
35
|
</div>
|
36
36
|
|
37
37
|
<div id="cart-form" data-hook="cart_form">
|
@@ -39,7 +39,7 @@
|
|
39
39
|
</div>
|
40
40
|
</div>
|
41
41
|
|
42
|
-
<div id="taxon-crumbs" class="
|
42
|
+
<div id="taxon-crumbs" class="mt-4" data-hook="product_taxons">
|
43
43
|
<%= render partial: 'taxons' %>
|
44
44
|
</div>
|
45
45
|
</div>
|
@@ -6,23 +6,43 @@
|
|
6
6
|
<% filters.each do |filter| %>
|
7
7
|
<% labels = filter[:labels] || filter[:conds].map {|m,c| [m,m]} %>
|
8
8
|
<% next if labels.empty? %>
|
9
|
-
<div
|
10
|
-
|
9
|
+
<div
|
10
|
+
class="navigation mt-4"
|
11
|
+
data-hook="navigation"
|
12
|
+
aria-labelledby="products_search_wrapper"
|
13
|
+
role="group">
|
14
|
+
|
15
|
+
<h4 class="filter-title mt-0 h5" id="products_search_wrapper">
|
16
|
+
<%= filter[:name] %>
|
17
|
+
</h4>
|
18
|
+
|
11
19
|
<ul class="list-group">
|
12
20
|
<% labels.each do |nm,val| %>
|
13
21
|
<% label = "#{filter[:name]}_#{nm}".gsub(/\s+/,'_') %>
|
14
22
|
<li class="list-group-item">
|
15
|
-
<
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
23
|
+
<div class="form-check">
|
24
|
+
<input
|
25
|
+
aria-labelledby="products_search_wrapper"
|
26
|
+
type="checkbox"
|
27
|
+
class="form-check-input"
|
28
|
+
id="<%= label %>"
|
29
|
+
name="search[<%= filter[:scope].to_s %>][]"
|
30
|
+
value="<%= val %>"
|
31
|
+
<%= params[:search].present? &&
|
32
|
+
params[:search][filter[:scope]] &&
|
33
|
+
params[:search][filter[:scope]].include?(val.to_s) ?
|
34
|
+
"checked" :
|
35
|
+
"" %> />
|
36
|
+
<label class="nowrap form-check-label" for="<%= label %>">
|
37
|
+
<%= nm %>
|
38
|
+
</label>
|
39
|
+
</div>
|
21
40
|
</li>
|
22
41
|
<% end %>
|
23
42
|
</ul>
|
24
43
|
</div>
|
25
44
|
<% end %>
|
26
|
-
|
45
|
+
|
46
|
+
<%= submit_tag Spree.t(:search), name: nil, class: 'mt-4 btn btn-primary' %>
|
27
47
|
<% end %>
|
28
48
|
<% end %>
|
@@ -1,8 +1,8 @@
|
|
1
1
|
<div id="spree-header">
|
2
|
-
<header id="header" data-hook>
|
2
|
+
<header id="header" data-hook class="py-3">
|
3
3
|
<div class="container">
|
4
4
|
<div class="row">
|
5
|
-
<figure id="logo" class="col-
|
5
|
+
<figure id="logo" class="col-3 col-md-4" data-hook>
|
6
6
|
<%= logo %>
|
7
7
|
</figure>
|
8
8
|
<%= render partial: 'spree/shared/nav_bar' %>
|
@@ -1,6 +1,12 @@
|
|
1
1
|
<% if spree_current_user %>
|
2
|
-
<li
|
3
|
-
|
2
|
+
<li>
|
3
|
+
<%= link_to Spree.t(:my_account), spree.account_path %>
|
4
|
+
</li>
|
5
|
+
<li>
|
6
|
+
<%= link_to Spree.t(:logout), spree.logout_path %>
|
7
|
+
</li>
|
4
8
|
<% else %>
|
5
|
-
<li id="link-to-login"
|
9
|
+
<li id="link-to-login">
|
10
|
+
<%= link_to Spree.t(:login), spree.login_path %>
|
11
|
+
</li>
|
6
12
|
<% end %>
|
@@ -1,16 +1,16 @@
|
|
1
|
-
<nav
|
2
|
-
<
|
3
|
-
<
|
4
|
-
|
5
|
-
</
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
</
|
15
|
-
</
|
1
|
+
<nav id="main-nav-bar" class="navbar">
|
2
|
+
<ul class="nav" data-hook>
|
3
|
+
<li id="home-link" class="nav-item" data-hook>
|
4
|
+
<%= link_to Spree.t(:home), spree.root_path, class: 'nav-link' %>
|
5
|
+
</li>
|
6
|
+
</ul>
|
7
|
+
<ul class="nav navbar-right" data-hook>
|
8
|
+
<li id="link-to-cart" class="nav-item" data-hook>
|
9
|
+
<noscript>
|
10
|
+
<%= link_to_cart %>
|
11
|
+
</noscript>
|
12
|
+
|
13
|
+
</li>
|
14
|
+
<script>Spree.fetch_cart()</script>
|
15
|
+
</ul>
|
16
16
|
</nav>
|
@@ -1,5 +1,5 @@
|
|
1
|
-
<nav class="navbar col-md-8 col-sm-9" id="top-nav-bar">
|
2
|
-
<ul id="nav-bar" class="nav
|
1
|
+
<nav class="navbar navbar-dark col-md-8 col-sm-9" id="top-nav-bar">
|
2
|
+
<ul id="nav-bar" class="nav align-items-center d-flex flex-column flex-sm-row navbar-right w-100 justify-content-start justify-content-md-end" data-hook>
|
3
3
|
<li id="search-bar" data-hook>
|
4
4
|
<%= render partial: 'spree/shared/search' %>
|
5
5
|
</li>
|