solidus_frontend 2.9.6 → 2.11.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.

Potentially problematic release.


This version of solidus_frontend might be problematic. Click here for more details.

Files changed (62) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/spree/frontend/checkout/address.js +1 -1
  3. data/app/assets/javascripts/spree/frontend/checkout/coupon-code.js +1 -1
  4. data/app/assets/stylesheets/spree/frontend/screen.css.scss +3 -3
  5. data/app/controllers/spree/checkout_controller.rb +13 -5
  6. data/app/controllers/spree/orders_controller.rb +13 -9
  7. data/app/controllers/spree/products_controller.rb +1 -1
  8. data/app/views/spree/address/_form.html.erb +15 -8
  9. data/app/views/spree/address/_form_hidden.html.erb +6 -2
  10. data/app/views/spree/checkout/payment/_gateway.html.erb +1 -1
  11. data/app/views/spree/orders/_form.html.erb +1 -1
  12. data/app/views/spree/shared/_address.html.erb +1 -1
  13. data/app/views/spree/shared/_image.html.erb +3 -2
  14. data/lib/generators/solidus/views/override_generator.rb +3 -2
  15. data/lib/spree/frontend/config.rb +9 -0
  16. data/lib/spree/frontend/engine.rb +5 -3
  17. data/lib/spree/frontend/middleware/seo_assist.rb +4 -4
  18. data/{app/models → lib}/spree/frontend_configuration.rb +1 -1
  19. data/solidus_frontend.gemspec +6 -5
  20. metadata +28 -56
  21. data/script/rails +0 -10
  22. data/spec/controllers/controller_helpers_spec.rb +0 -29
  23. data/spec/controllers/locale_controller_spec.rb +0 -57
  24. data/spec/controllers/spree/checkout_controller_spec.rb +0 -610
  25. data/spec/controllers/spree/checkout_controller_with_views_spec.rb +0 -37
  26. data/spec/controllers/spree/content_controller_spec.rb +0 -9
  27. data/spec/controllers/spree/current_order_tracking_spec.rb +0 -47
  28. data/spec/controllers/spree/home_controller_spec.rb +0 -29
  29. data/spec/controllers/spree/orders_controller_ability_spec.rb +0 -90
  30. data/spec/controllers/spree/orders_controller_spec.rb +0 -229
  31. data/spec/controllers/spree/orders_controller_transitions_spec.rb +0 -33
  32. data/spec/controllers/spree/products_controller_spec.rb +0 -38
  33. data/spec/controllers/spree/taxons_controller_spec.rb +0 -14
  34. data/spec/features/address_spec.rb +0 -78
  35. data/spec/features/automatic_promotion_adjustments_spec.rb +0 -49
  36. data/spec/features/caching/products_spec.rb +0 -48
  37. data/spec/features/caching/taxons_spec.rb +0 -21
  38. data/spec/features/cart_spec.rb +0 -85
  39. data/spec/features/checkout_confirm_insufficient_stock_spec.rb +0 -71
  40. data/spec/features/checkout_spec.rb +0 -707
  41. data/spec/features/checkout_unshippable_spec.rb +0 -37
  42. data/spec/features/coupon_code_spec.rb +0 -266
  43. data/spec/features/currency_spec.rb +0 -20
  44. data/spec/features/first_order_promotion_spec.rb +0 -59
  45. data/spec/features/free_shipping_promotions_spec.rb +0 -60
  46. data/spec/features/locale_spec.rb +0 -26
  47. data/spec/features/order_spec.rb +0 -73
  48. data/spec/features/products_spec.rb +0 -291
  49. data/spec/features/promotion_code_invalidation_spec.rb +0 -54
  50. data/spec/features/quantity_promotions_spec.rb +0 -130
  51. data/spec/features/taxons_spec.rb +0 -158
  52. data/spec/features/template_rendering_spec.rb +0 -20
  53. data/spec/fixtures/thinking-cat.jpg +0 -0
  54. data/spec/generators/solidus/views/override_generator_spec.rb +0 -50
  55. data/spec/helpers/base_helper_spec.rb +0 -13
  56. data/spec/helpers/order_helper_spec.rb +0 -14
  57. data/spec/helpers/taxon_filters_helper_spec.rb +0 -12
  58. data/spec/spec_helper.rb +0 -106
  59. data/spec/support/shared_contexts/checkout_setup.rb +0 -12
  60. data/spec/support/shared_contexts/custom_products.rb +0 -28
  61. data/spec/support/shared_contexts/locales.rb +0 -16
  62. data/spec/views/spree/checkout/_summary_spec.rb +0 -11
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 59a3b04e427501e6c465c89d3a7a5278be8b999ab29dbbe0af9841df1d1032c8
4
- data.tar.gz: f62b17d100120614790bf81f0f0f202f1b55918489b242f8b89cb311406f96a2
3
+ metadata.gz: 8276f0fe5ca9fe4d4a2d8d327f7d9b5a747564c69a101bf95168f3462e8ce6b3
4
+ data.tar.gz: c51e8b73de741bc504e151d55a79e3715a37f4bc88a574d4a9c96b6ceae889c4
5
5
  SHA512:
6
- metadata.gz: 7385f7eb310a92fcb4eaf18b2fd377cf08ee0c863bd806724dd860ad70d99dceadb59807edf6dcd6b8d2608a12e1064f301c912664d44616c235f6ac79e6ec6e
7
- data.tar.gz: dda5bfdd5c4c33f6bbdda2692d24a24ec0953686c4ebfec47137451fd830a7a36e884b1577fef5a24f03c0007f95401820c6118ac38e2ed6452215f449d22454
6
+ metadata.gz: dcc274c38109e0f2bae29bc3820f13d679705b5132657950983e2347bc3d4d5e8c23c7e74a92e0961f21d6a38323b0b367e561a92ee2a06642eebaf1f33ebfaa
7
+ data.tar.gz: 01366c21ebae0cebdb9e7fbfdd2f1778ea54159ff5f0c627e093c0fcd70cbd49d18d1e4a781c41212cee42e560f0684e74b74efc949a3860e12d21a8e96cf247
@@ -14,7 +14,7 @@ Spree.ready(function($) {
14
14
  if (countryId != null) {
15
15
  if (statesByCountry[countryId] == null) {
16
16
  $.get(
17
- Spree.routes.states_search,
17
+ Spree.pathFor('api/states'),
18
18
  {
19
19
  country_id: countryId
20
20
  },
@@ -15,7 +15,7 @@ Spree.onCouponCodeApply = function(e) {
15
15
  };
16
16
  var req = Spree.ajax({
17
17
  method: 'POST',
18
- url: Spree.routes.apply_coupon_code(Spree.current_order_id),
18
+ url: Spree.pathFor('api/orders/' + Spree.current_order_id + '/coupon_codes'),
19
19
  data: JSON.stringify(data),
20
20
  contentType: "application/json"
21
21
  });
@@ -963,8 +963,8 @@ p[data-hook="use_billing"] {
963
963
  }
964
964
 
965
965
  input[type="text"] {
966
- flex: 3 0;
967
- width: 100%;
966
+ flex: 1 auto;
967
+ width: 50%;
968
968
  margin-right: 5px;
969
969
  }
970
970
 
@@ -1268,7 +1268,7 @@ table.order-summary {
1268
1268
  // # Logo
1269
1269
  #logo {
1270
1270
  padding: 20px 0;
1271
-
1271
+
1272
1272
  > a {
1273
1273
  display: inline-block;
1274
1274
  }
@@ -8,8 +8,8 @@ module Spree
8
8
  class CheckoutController < Spree::StoreController
9
9
  before_action :load_order
10
10
  around_action :lock_order
11
- before_action :set_state_if_present
12
11
 
12
+ before_action :ensure_order_is_not_skipping_states
13
13
  before_action :ensure_order_not_completed
14
14
  before_action :ensure_checkout_allowed
15
15
  before_action :ensure_sufficient_stock_lines
@@ -149,13 +149,22 @@ module Spree
149
149
  redirect_to(spree.cart_path) && return unless @order
150
150
  end
151
151
 
152
- def set_state_if_present
152
+ # Allow the customer to only go back or stay on the current state
153
+ # when trying to change it via params[:state]. It's not allowed to
154
+ # jump forward and skip states (unless #skip_state_validation? is
155
+ # truthy).
156
+ def ensure_order_is_not_skipping_states
153
157
  if params[:state]
154
158
  redirect_to checkout_state_path(@order.state) if @order.can_go_to_state?(params[:state]) && !skip_state_validation?
155
159
  @order.state = params[:state]
156
160
  end
157
161
  end
158
162
 
163
+ def set_state_if_present
164
+ ensure_order_is_not_skipping_states
165
+ end
166
+ deprecate set_state_if_present: :prevent_order_from_skipping_states, deprecator: Spree::Deprecation
167
+
159
168
  def ensure_checkout_allowed
160
169
  unless @order.checkout_allowed?
161
170
  redirect_to spree.cart_path
@@ -206,9 +215,8 @@ module Spree
206
215
  @order.assign_default_user_addresses
207
216
  # If the user has a default address, the previous method call takes care
208
217
  # of setting that; but if he doesn't, we need to build an empty one here
209
- default = { country_id: Spree::Country.default.id }
210
- @order.build_bill_address(default) unless @order.bill_address
211
- @order.build_ship_address(default) if @order.checkout_steps.include?('delivery') && !@order.ship_address
218
+ @order.bill_address ||= Spree::Address.build_default
219
+ @order.ship_address ||= Spree::Address.build_default if @order.checkout_steps.include?('delivery')
212
220
  end
213
221
 
214
222
  def before_delivery
@@ -15,7 +15,7 @@ module Spree
15
15
 
16
16
  def show
17
17
  @order = Spree::Order.find_by!(number: params[:id])
18
- authorize! :read, @order, cookies.signed[:guest_token]
18
+ authorize! :show, @order, cookies.signed[:guest_token]
19
19
  end
20
20
 
21
21
  def update
@@ -39,9 +39,13 @@ module Spree
39
39
 
40
40
  # Shows the current incomplete order from the session
41
41
  def edit
42
- @order = current_order || Spree::Order.incomplete.find_or_initialize_by(guest_token: cookies.signed[:guest_token])
43
- authorize! :read, @order, cookies.signed[:guest_token]
42
+ @order = current_order(build_order_if_necessary: true)
43
+ authorize! :edit, @order, cookies.signed[:guest_token]
44
44
  associate_user
45
+ if params[:id] && @order.number != params[:id]
46
+ flash[:error] = t('spree.cannot_edit_orders')
47
+ redirect_to cart_path
48
+ end
45
49
  end
46
50
 
47
51
  # Adds a new item to the order (creating a new order if none already exists)
@@ -55,12 +59,12 @@ module Spree
55
59
  # 2,147,483,647 is crazy. See issue https://github.com/spree/spree/issues/2695.
56
60
  if !quantity.between?(1, 2_147_483_647)
57
61
  @order.errors.add(:base, t('spree.please_enter_reasonable_quantity'))
58
- end
59
-
60
- begin
61
- @line_item = @order.contents.add(variant, quantity)
62
- rescue ActiveRecord::RecordInvalid => e
63
- @order.errors.add(:base, e.record.errors.full_messages.join(", "))
62
+ else
63
+ begin
64
+ @line_item = @order.contents.add(variant, quantity)
65
+ rescue ActiveRecord::RecordInvalid => error
66
+ @order.errors.add(:base, error.record.errors.full_messages.join(", "))
67
+ end
64
68
  end
65
69
 
66
70
  respond_with(@order) do |format|
@@ -38,7 +38,7 @@ module Spree
38
38
 
39
39
  def load_product
40
40
  if try_spree_current_user.try(:has_spree_role?, "admin")
41
- @products = Spree::Product.with_deleted
41
+ @products = Spree::Product.with_discarded
42
42
  else
43
43
  @products = Spree::Product.available
44
44
  end
@@ -1,14 +1,21 @@
1
1
  <% address_id = address_type.chars.first %>
2
2
  <div class="inner" data-hook=<%="#{address_type}_inner" %>>
3
- <div class="field field-required" id=<%="#{address_id}firstname" %>>
4
- <%= form.label :firstname, t('spree.first_name') %>
5
- <%= form.text_field :firstname, class: 'required', autocomplete: address_type + ' given-name', required: true, autofocus: true %>
6
- </div>
3
+ <% if Spree::Config.use_combined_first_and_last_name_in_address %>
4
+ <div class="field field-required" id="<%= "#{address_id}name" %>">
5
+ <%= form.label :name, t('spree.name') %>
6
+ <%= form.text_field :name, class: 'required', autocomplete: address_type + ' name', required: true, autofocus: true %>
7
+ </div>
8
+ <% else %>
9
+ <div class="field field-required" id="<%= "#{address_id}firstname" %>">
10
+ <%= form.label :firstname, t('spree.first_name') %>
11
+ <%= form.text_field :firstname, class: 'required', autocomplete: address_type + ' given-name', required: true, autofocus: true %>
12
+ </div>
7
13
 
8
- <div class="field" id=<%="#{address_id}lastname" %>>
9
- <%= form.label :lastname, t('spree.last_name') %>
10
- <%= form.text_field :lastname, autocomplete: address_type + ' family-name' %>
11
- </div>
14
+ <div class="field" id="<%= "#{address_id}lastname" %>">
15
+ <%= form.label :lastname, t('spree.last_name') %>
16
+ <%= form.text_field :lastname, autocomplete: address_type + ' family-name' %>
17
+ </div>
18
+ <% end %>
12
19
 
13
20
  <% if Spree::Config[:company] %>
14
21
  <div class="field" id=<%="#{address_id}company" %>>
@@ -1,5 +1,9 @@
1
- <%= form.hidden_field :firstname %>
2
- <%= form.hidden_field :lastname %>
1
+ <% if Spree::Config.use_combined_first_and_last_name_in_address %>
2
+ <%= form.hidden_field :name %>
3
+ <% else %>
4
+ <%= form.hidden_field :firstname %>
5
+ <%= form.hidden_field :lastname %>
6
+ <% end %>
3
7
  <%= form.hidden_field :company %>
4
8
  <%= form.hidden_field :address1 %>
5
9
  <%= form.hidden_field :address2 %>
@@ -3,7 +3,7 @@
3
3
 
4
4
  <div class="field field-required card_name" data-hook="card_name">
5
5
  <%= label_tag "name_on_card_#{payment_method.id}", t('spree.name_on_card') %>
6
- <%= text_field_tag "#{param_prefix}[name]", "#{@order.billing_firstname} #{@order.billing_lastname}", { id: "name_on_card_#{payment_method.id}", autocomplete: "cc-name", class: 'cardName' } %>
6
+ <%= text_field_tag "#{param_prefix}[name]", @order.billing_name, { id: "name_on_card_#{payment_method.id}", autocomplete: "cc-name", class: 'cardName' } %>
7
7
  </div>
8
8
 
9
9
  <div class="field field-required card_number" data-hook="card_number">
@@ -13,7 +13,7 @@
13
13
  <tbody id="line_items" data-hook>
14
14
  <%= render partial: 'spree/orders/line_item', collection: order.line_items, locals: { order_form: order_form } %>
15
15
  </tbody>
16
- <% if order.adjustments.nonzero.exists? || order.line_item_adjustments.nonzero.exists? || order.shipment_adjustments.nonzero.exists? || order.shipments.any? %>
16
+ <% if order.all_adjustments.nonzero.any? || order.shipments.any? %>
17
17
  <tr class="cart-subtotal">
18
18
  <td colspan="4" align='right'><h5><%= t('spree.cart_subtotal', count: order.line_items.sum(:quantity)) %></h5></td>
19
19
  <td colspan><h5><%= order.display_item_total %></h5></td>
@@ -1,5 +1,5 @@
1
1
  <div class="address vcard">
2
- <div class="fn"><%= address.full_name %></div>
2
+ <div class="fn"><%= address.name %></div>
3
3
  <% unless address.company.blank? %>
4
4
  <div class="org">
5
5
  <%= address.company %>
@@ -1,11 +1,12 @@
1
1
  <% size ||= :mini %>
2
2
  <% itemprop ||= nil %>
3
+ <% options ||= {} %>
3
4
 
4
5
  <% if image_url = image.try(:url, size) %>
5
6
  <% if image_alt = image.try(:alt) %>
6
- <%= image_tag image_url, alt: image_alt, itemprop: itemprop %>
7
+ <%= image_tag image_url, { alt: image_alt, itemprop: itemprop }.merge(options) %>
7
8
  <% else %>
8
- <%= image_tag image_url, itemprop: itemprop %>
9
+ <%= image_tag image_url, { itemprop: itemprop }.merge(options) %>
9
10
  <% end %>
10
11
  <% else %>
11
12
  <span class="image-placeholder <%= size %>"></span>
@@ -24,6 +24,7 @@ module Solidus
24
24
  def copy_views
25
25
  views_to_copy.each do |file|
26
26
  next if File.directory?(file)
27
+
27
28
  dest_file = Pathname.new(file).relative_path_from(source_dir)
28
29
  copy_file file, Rails.root.join('app', 'views', 'spree', dest_file)
29
30
  end
@@ -33,8 +34,8 @@ module Solidus
33
34
 
34
35
  def views_to_copy
35
36
  if @options['only']
36
- VIEWS.select do |v|
37
- Pathname.new(v).relative_path_from(source_dir).to_s.include?(@options['only'])
37
+ VIEWS.select do |view|
38
+ Pathname.new(view).relative_path_from(source_dir).to_s.include?(@options['only'])
38
39
  end
39
40
  else
40
41
  VIEWS
@@ -0,0 +1,9 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'spree/frontend_configuration'
4
+
5
+ module Spree
6
+ module Frontend
7
+ Config = Spree::FrontendConfiguration.new
8
+ end
9
+ end
@@ -1,13 +1,15 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require 'spree/frontend/config'
4
+
3
5
  module Spree
4
6
  module Frontend
5
7
  class Engine < ::Rails::Engine
6
8
  config.middleware.use "Spree::Frontend::Middleware::SeoAssist"
7
9
 
8
- initializer "spree.frontend.environment", before: :load_config_initializers do |_app|
9
- Spree::Frontend::Config = Spree::FrontendConfiguration.new
10
- end
10
+ # Leave initializer empty for backwards-compatability. Other apps
11
+ # might still rely on this event.
12
+ initializer "spree.frontend.environment", before: :load_config_initializers do; end
11
13
  end
12
14
  end
13
15
  end
@@ -38,11 +38,11 @@ module Spree
38
38
  end
39
39
 
40
40
  def build_query(params)
41
- params.map { |k, v|
42
- if v.class == Array
43
- build_query(v.map { |x| ["#{k}[]", x] })
41
+ params.map { |key, value|
42
+ if value.class == Array
43
+ build_query(value.map { |parameter| ["#{key}[]", parameter] })
44
44
  else
45
- k + "=" + Rack::Utils.escape(v)
45
+ key + "=" + Rack::Utils.escape(value)
46
46
  end
47
47
  }.join("&")
48
48
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Spree
4
4
  class FrontendConfiguration < Preferences::Configuration
5
- preference :locale, :string, default: Rails.application.config.i18n.default_locale
5
+ preference :locale, :string, default: I18n.default_locale
6
6
 
7
7
  # Add your terms and conditions in app/views/spree/checkout/_terms_and_conditions.en.html.erb
8
8
  preference :require_terms_and_conditions_acceptance, :boolean, default: false
@@ -11,14 +11,14 @@ Gem::Specification.new do |s|
11
11
 
12
12
  s.author = 'Solidus Team'
13
13
  s.email = 'contact@solidus.io'
14
- s.homepage = 'http://solidus.io/'
14
+ s.homepage = 'http://solidus.io'
15
15
  s.license = 'BSD-3-Clause'
16
16
 
17
- s.files = `git ls-files`.split("\n")
18
- s.require_path = 'lib'
19
- s.requirements << 'none'
17
+ s.files = `git ls-files -z`.split("\x0").reject do |f|
18
+ f.match(%r{^(spec|script)/})
19
+ end
20
20
 
21
- s.required_ruby_version = '>= 2.2.2'
21
+ s.required_ruby_version = '>= 2.5.0'
22
22
  s.required_rubygems_version = '>= 1.8.23'
23
23
 
24
24
  s.add_dependency 'solidus_api', s.version
@@ -28,6 +28,7 @@ Gem::Specification.new do |s|
28
28
  s.add_dependency 'font-awesome-rails', '~> 4.0'
29
29
  s.add_dependency 'jquery-rails'
30
30
  s.add_dependency 'kaminari', '~> 1.1'
31
+ s.add_dependency 'responders'
31
32
  s.add_dependency 'sassc-rails'
32
33
  s.add_dependency 'truncate_html', '~> 0.9', '>= 0.9.2'
33
34
 
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: solidus_frontend
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.9.6
4
+ version: 2.11.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Solidus Team
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-07-16 00:00:00.000000000 Z
11
+ date: 2020-10-23 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: solidus_api
@@ -16,28 +16,28 @@ dependencies:
16
16
  requirements:
17
17
  - - '='
18
18
  - !ruby/object:Gem::Version
19
- version: 2.9.6
19
+ version: 2.11.0
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: 2.9.6
26
+ version: 2.11.0
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: solidus_core
29
29
  requirement: !ruby/object:Gem::Requirement
30
30
  requirements:
31
31
  - - '='
32
32
  - !ruby/object:Gem::Version
33
- version: 2.9.6
33
+ version: 2.11.0
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: 2.9.6
40
+ version: 2.11.0
41
41
  - !ruby/object:Gem::Dependency
42
42
  name: canonical-rails
43
43
  requirement: !ruby/object:Gem::Requirement
@@ -94,6 +94,20 @@ dependencies:
94
94
  - - "~>"
95
95
  - !ruby/object:Gem::Version
96
96
  version: '1.1'
97
+ - !ruby/object:Gem::Dependency
98
+ name: responders
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ">="
102
+ - !ruby/object:Gem::Version
103
+ version: '0'
104
+ type: :runtime
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
97
111
  - !ruby/object:Gem::Dependency
98
112
  name: sassc-rails
99
113
  requirement: !ruby/object:Gem::Requirement
@@ -204,7 +218,6 @@ files:
204
218
  - app/controllers/spree/taxons_controller.rb
205
219
  - app/helpers/spree/orders_helper.rb
206
220
  - app/helpers/spree/taxon_filters_helper.rb
207
- - app/models/spree/frontend_configuration.rb
208
221
  - app/views/spree/address/_form.html.erb
209
222
  - app/views/spree/address/_form_hidden.html.erb
210
223
  - app/views/spree/checkout/_address.html.erb
@@ -264,59 +277,19 @@ files:
264
277
  - lib/generators/solidus/views/override_generator.rb
265
278
  - lib/solidus_frontend.rb
266
279
  - lib/spree/frontend.rb
280
+ - lib/spree/frontend/config.rb
267
281
  - lib/spree/frontend/engine.rb
268
282
  - lib/spree/frontend/middleware/seo_assist.rb
283
+ - lib/spree/frontend_configuration.rb
269
284
  - lib/spree_frontend.rb
270
285
  - lib/tasks/rake_util.rb
271
286
  - lib/tasks/taxon.rake
272
- - script/rails
273
287
  - solidus_frontend.gemspec
274
- - spec/controllers/controller_helpers_spec.rb
275
- - spec/controllers/locale_controller_spec.rb
276
- - spec/controllers/spree/checkout_controller_spec.rb
277
- - spec/controllers/spree/checkout_controller_with_views_spec.rb
278
- - spec/controllers/spree/content_controller_spec.rb
279
- - spec/controllers/spree/current_order_tracking_spec.rb
280
- - spec/controllers/spree/home_controller_spec.rb
281
- - spec/controllers/spree/orders_controller_ability_spec.rb
282
- - spec/controllers/spree/orders_controller_spec.rb
283
- - spec/controllers/spree/orders_controller_transitions_spec.rb
284
- - spec/controllers/spree/products_controller_spec.rb
285
- - spec/controllers/spree/taxons_controller_spec.rb
286
- - spec/features/address_spec.rb
287
- - spec/features/automatic_promotion_adjustments_spec.rb
288
- - spec/features/caching/products_spec.rb
289
- - spec/features/caching/taxons_spec.rb
290
- - spec/features/cart_spec.rb
291
- - spec/features/checkout_confirm_insufficient_stock_spec.rb
292
- - spec/features/checkout_spec.rb
293
- - spec/features/checkout_unshippable_spec.rb
294
- - spec/features/coupon_code_spec.rb
295
- - spec/features/currency_spec.rb
296
- - spec/features/first_order_promotion_spec.rb
297
- - spec/features/free_shipping_promotions_spec.rb
298
- - spec/features/locale_spec.rb
299
- - spec/features/order_spec.rb
300
- - spec/features/products_spec.rb
301
- - spec/features/promotion_code_invalidation_spec.rb
302
- - spec/features/quantity_promotions_spec.rb
303
- - spec/features/taxons_spec.rb
304
- - spec/features/template_rendering_spec.rb
305
- - spec/fixtures/thinking-cat.jpg
306
- - spec/generators/solidus/views/override_generator_spec.rb
307
- - spec/helpers/base_helper_spec.rb
308
- - spec/helpers/order_helper_spec.rb
309
- - spec/helpers/taxon_filters_helper_spec.rb
310
- - spec/spec_helper.rb
311
- - spec/support/shared_contexts/checkout_setup.rb
312
- - spec/support/shared_contexts/custom_products.rb
313
- - spec/support/shared_contexts/locales.rb
314
- - spec/views/spree/checkout/_summary_spec.rb
315
- homepage: http://solidus.io/
288
+ homepage: http://solidus.io
316
289
  licenses:
317
290
  - BSD-3-Clause
318
291
  metadata: {}
319
- post_install_message:
292
+ post_install_message:
320
293
  rdoc_options: []
321
294
  require_paths:
322
295
  - lib
@@ -324,16 +297,15 @@ required_ruby_version: !ruby/object:Gem::Requirement
324
297
  requirements:
325
298
  - - ">="
326
299
  - !ruby/object:Gem::Version
327
- version: 2.2.2
300
+ version: 2.5.0
328
301
  required_rubygems_version: !ruby/object:Gem::Requirement
329
302
  requirements:
330
303
  - - ">="
331
304
  - !ruby/object:Gem::Version
332
305
  version: 1.8.23
333
- requirements:
334
- - none
306
+ requirements: []
335
307
  rubygems_version: 3.0.3
336
- signing_key:
308
+ signing_key:
337
309
  specification_version: 4
338
310
  summary: Cart and storefront for the Solidus e-commerce project.
339
311
  test_files: []