solidus_reviews 1.0.0 → 1.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (126) hide show
  1. checksums.yaml +5 -5
  2. data/.circleci/config.yml +35 -0
  3. data/.gem_release.yml +5 -0
  4. data/.github/stale.yml +17 -0
  5. data/.gitignore +12 -8
  6. data/.rspec +1 -1
  7. data/.rubocop.yml +2 -0
  8. data/.rubocop_todo.yml +221 -0
  9. data/CHANGELOG.md +132 -0
  10. data/Gemfile +17 -3
  11. data/{LICENSE.md → LICENSE} +2 -2
  12. data/README.md +33 -50
  13. data/Rakefile +5 -18
  14. data/app/controllers/spree/admin/feedback_reviews_controller.rb +3 -1
  15. data/app/controllers/spree/admin/review_settings_controller.rb +3 -1
  16. data/app/controllers/spree/admin/reviews_controller.rb +9 -6
  17. data/app/controllers/spree/feedback_reviews_controller.rb +19 -19
  18. data/app/controllers/spree/reviews_controller.rb +38 -7
  19. data/app/decorators/controllers/solidus_reviews/spree/products_controller_decorator.rb +15 -0
  20. data/app/decorators/helpers/solidus_reviews/spree/api/api_helpers_decorator.rb +33 -0
  21. data/app/decorators/models/solidus_reviews/spree/product_decorator.rb +31 -0
  22. data/app/decorators/models/solidus_reviews/spree/user_decorator.rb +15 -0
  23. data/app/helpers/spree/reviews_helper.rb +15 -5
  24. data/app/models/spree/feedback_review.rb +7 -6
  25. data/app/models/spree/permission_sets/review_display.rb +11 -0
  26. data/app/models/spree/permission_sets/review_management.rb +11 -0
  27. data/app/models/spree/review.rb +46 -13
  28. data/app/models/spree/reviews_ability.rb +24 -5
  29. data/app/models/spree/reviews_configuration.rb +25 -8
  30. data/app/overrides/add_reviews_after_product_properties.rb +7 -5
  31. data/app/overrides/add_reviews_tab_to_admin.rb +20 -4
  32. data/app/overrides/add_reviews_to_admin_configuration_sidebar.rb +20 -5
  33. data/app/views/spree/admin/feedback_reviews/index.html.erb +9 -9
  34. data/app/views/spree/admin/review_settings/edit.html.erb +71 -35
  35. data/app/views/spree/admin/reviews/_form.html.erb +26 -5
  36. data/app/views/spree/admin/reviews/edit.html.erb +5 -3
  37. data/app/views/spree/admin/reviews/index.html.erb +104 -88
  38. data/app/views/spree/api/reviews/_feedback_review.json.jbuilder +5 -0
  39. data/app/views/spree/api/reviews/_review.json.jbuilder +11 -0
  40. data/app/views/spree/api/reviews/index.json.jbuilder +6 -0
  41. data/app/views/spree/api/reviews/show.json.jbuilder +3 -0
  42. data/app/views/spree/feedback_reviews/_form.html.erb +5 -5
  43. data/app/views/spree/feedback_reviews/_summary.html.erb +3 -3
  44. data/app/views/spree/feedback_reviews/create.js.erb +2 -2
  45. data/app/views/spree/reviews/_form.html.erb +17 -10
  46. data/app/views/spree/reviews/edit.html.erb +3 -0
  47. data/app/views/spree/reviews/new.html.erb +2 -2
  48. data/app/views/spree/shared/_rating.html.erb +3 -3
  49. data/app/views/spree/shared/_review.html.erb +31 -19
  50. data/app/views/spree/shared/_review_summary.html.erb +3 -3
  51. data/app/views/spree/shared/_reviews.html.erb +6 -6
  52. data/app/views/spree/shared/_shortrating.html.erb +2 -2
  53. data/bin/console +17 -0
  54. data/bin/rails +13 -3
  55. data/bin/setup +8 -0
  56. data/config/initializers/constants.rb +2 -0
  57. data/config/initializers/load_preferences.rb +2 -0
  58. data/config/locales/de-CH.yml +15 -2
  59. data/config/locales/de.yml +15 -2
  60. data/config/locales/en-GB.yml +16 -3
  61. data/config/locales/en.yml +16 -2
  62. data/config/locales/es.yml +16 -3
  63. data/config/locales/fr.yml +15 -3
  64. data/config/locales/it.yml +79 -0
  65. data/config/locales/pl.yml +15 -3
  66. data/config/locales/pt-BR.yml +15 -3
  67. data/config/locales/pt.yml +15 -3
  68. data/config/locales/ro.yml +16 -4
  69. data/config/locales/ru.yml +14 -2
  70. data/config/locales/sv.yml +15 -2
  71. data/config/locales/tr.yml +15 -3
  72. data/config/locales/uk.yml +15 -2
  73. data/config/locales/zh-CN.yml +15 -2
  74. data/config/locales/zh-TW.yml +15 -2
  75. data/config/routes.rb +21 -2
  76. data/db/migrate/20081020220724_create_reviews.rb +4 -2
  77. data/db/migrate/20101222083309_create_feedback_reviews.rb +5 -3
  78. data/db/migrate/20110406083603_add_rating_to_products.rb +7 -5
  79. data/db/migrate/20110606150524_add_user_to_reviews.rb +4 -2
  80. data/db/migrate/20110806093221_add_ip_address_to_reviews.rb +3 -1
  81. data/db/migrate/20120110172331_namespace_tables.rb +3 -1
  82. data/db/migrate/20120123141326_recalculate_ratings.rb +7 -7
  83. data/db/migrate/20120712182514_add_locale_to_reviews.rb +4 -2
  84. data/db/migrate/20120712182627_add_locale_to_feedback_reviews.rb +4 -2
  85. data/db/migrate/20140703200946_add_show_identifier_to_reviews.rb +3 -1
  86. data/db/migrate/20190613165528_add_verified_purchaser_to_reviews.rb +7 -0
  87. data/lib/controllers/spree/api/feedback_reviews_controller.rb +91 -0
  88. data/lib/controllers/spree/api/reviews_controller.rb +113 -0
  89. data/lib/generators/solidus_reviews/install/install_generator.rb +5 -4
  90. data/lib/solidus_reviews.rb +7 -5
  91. data/lib/solidus_reviews/engine.rb +26 -0
  92. data/lib/solidus_reviews/factories.rb +3 -1
  93. data/lib/solidus_reviews/factories/feedback_review_factory.rb +6 -5
  94. data/lib/solidus_reviews/factories/review_factory.rb +19 -9
  95. data/lib/solidus_reviews/version.rb +5 -0
  96. data/solidus_reviews.gemspec +32 -32
  97. data/spec/controllers/{admin → spree/admin}/feedback_reviews_controller_spec.rb +10 -8
  98. data/spec/controllers/spree/admin/review_settings_controller_spec.rb +58 -0
  99. data/spec/controllers/spree/admin/reviews_controller_spec.rb +65 -0
  100. data/spec/controllers/spree/api/feedback_reviews_controller_spec.rb +136 -0
  101. data/spec/controllers/spree/api/reviews_controller_spec.rb +238 -0
  102. data/spec/controllers/spree/feedback_reviews_controller_spec.rb +75 -0
  103. data/spec/controllers/spree/reviews_controller_spec.rb +298 -0
  104. data/spec/features/admin_spec.rb +9 -6
  105. data/spec/features/reviews_spec.rb +54 -37
  106. data/spec/helpers/review_helper_spec.rb +3 -2
  107. data/spec/models/feedback_review_spec.rb +19 -17
  108. data/spec/models/product_spec.rb +49 -24
  109. data/spec/models/review_spec.rb +133 -52
  110. data/spec/models/reviews_ability_spec.rb +16 -14
  111. data/spec/models/reviews_configuration_spec.rb +46 -26
  112. data/spec/spec_helper.rb +13 -44
  113. data/spec/support/config.rb +7 -0
  114. data/spec/support/factories.rb +3 -0
  115. data/vendor/assets/javascripts/jquery.rating.js +389 -376
  116. metadata +81 -190
  117. data/.travis.yml +0 -18
  118. data/CONTRIBUTING.md +0 -28
  119. data/app/controllers/spree/products_controller_decorator.rb +0 -5
  120. data/app/models/spree/product_decorator.rb +0 -21
  121. data/lib/spree_reviews/engine.rb +0 -17
  122. data/spec/controllers/admin/review_settings_controller_spec.rb +0 -57
  123. data/spec/controllers/admin/reviews_controller_spec.rb +0 -63
  124. data/spec/controllers/feedback_reviews_controller_spec.rb +0 -71
  125. data/spec/controllers/products_controller_spec.rb +0 -9
  126. data/spec/controllers/reviews_controller_spec.rb +0 -136
@@ -1,22 +1,43 @@
1
- <%= render "spree/shared/error_messages", :target => @review %>
1
+ <%= render "spree/shared/error_messages", target: @review %>
2
2
  <%= f.field_container :name do %>
3
3
  <%= f.label :name %><br />
4
- <%= f.text_field :name, :maxlength => "255", :size => "60" %>
4
+ <%= f.text_field :name, maxlength: "255", size: "60" %>
5
+ <% end %>
6
+
7
+ <%= f.field_container :email do %>
8
+ <%= f.label :email %><br />
9
+ <%= mail_to @review.email %>
5
10
  <% end %>
6
11
 
7
12
  <%= f.field_container :title do %>
8
13
  <%= f.label :title %><br />
9
- <%= f.text_field :title, :maxlength => "255", :size => "60" %>
14
+ <%= f.text_field :title, maxlength: "255", size: "60" %>
10
15
  <% end %>
11
16
 
12
17
  <%= f.field_container :review do %>
13
18
  <%= f.label :review %><br />
14
- <%= f.text_area :review, :wrap => "virtual", :rows => "10", :cols => "60" %>
19
+ <%= f.text_area :review, wrap: "virtual", rows: "10", cols: "60" %>
20
+ <% end %>
21
+
22
+ <%= f.field_container :images do %>
23
+ <%= f.label :images %>
24
+ <table>
25
+ <% @review.images.each do |image| %>
26
+ <tr>
27
+ <td>
28
+ <%= image_tag image.url(:original) %>
29
+ </td>
30
+ <td>
31
+ <%= link_to_delete image, url: admin_review_image_url(@review, image, product_id: @review.product), no_text: true %>
32
+ </td>
33
+ </tr>
34
+ <% end %>
35
+ </table>
15
36
  <% end %>
16
37
 
17
38
  <% if Spree::Reviews::Config[:track_locale] %>
18
39
  <%= f.field_container :locale do %>
19
40
  <%= f.label :locale %><br />
20
- <%= f.select :locale, I18n.available_locales.map { |lc| [t(lc, :default => lc.to_s), lc.to_s] } %>
41
+ <%= f.select :locale, I18n.available_locales.map { |lc| [t(lc, default: lc.to_s), lc.to_s] } %>
21
42
  <% end %>
22
43
  <% end %>
@@ -1,5 +1,5 @@
1
1
  <% content_for :page_title do %>
2
- <%= Spree.t(:editing_review_for_html, :link => link_to(@review.product.name, product_path(@review.product))) %>
2
+ <%= I18n.t("spree.editing_review_for_html", product_name: @review.product.name) %>
3
3
  <% end %>
4
4
 
5
5
  <% render 'spree/admin/shared/product_sub_menu' %>
@@ -15,12 +15,14 @@
15
15
  </div>
16
16
 
17
17
  <div class="omega eight columns">
18
- <%= render 'form', :f => f %>
18
+ <%= render 'form', f: f %>
19
19
  </div>
20
20
 
21
21
  <div class="clear"></div>
22
22
 
23
23
  <fieldset class="no-border-top">
24
- <%= render 'spree/admin/shared/edit_resource_links' %>
24
+ <% if can? :manage, Spree::Review %>
25
+ <%= render 'spree/admin/shared/edit_resource_links' %>
26
+ <% end %>
25
27
  </fieldset>
26
28
  <% end %>
@@ -1,111 +1,127 @@
1
+ <% admin_breadcrumb(link_to plural_resource_name(Spree::Product), spree.admin_products_path) %>
2
+
1
3
  <% content_for :page_title do %>
2
- <%= Spree.t('reviews') %>
4
+ <%= I18n.t("spree.reviews") %>
3
5
  <% end %>
4
6
 
5
- <% render 'spree/admin/shared/product_sub_menu' %>
6
-
7
7
  <% content_for :table_filter_title do %>
8
- <%= Spree.t('search') %>
8
+ <% if can? :display, Spree::Review %>
9
+ <%= I18n.t("spree.search") %>
10
+ <% end %>
9
11
  <% end %>
10
12
 
11
13
  <% content_for :table_filter do %>
12
14
  <div data-hook="admin_reviews_index_search">
13
-
14
15
  <%= search_form_for [:admin, @search] do |f| %>
15
- <div class="alpha three columns">
16
- <div class="field">
17
- <%= label_tag nil, Spree.t(:user) %><br />
18
- <%= f.text_field :name_cont, :size => 25 %>
19
- </div>
20
- </div>
16
+ <div class="alpha three columns">
17
+ <div class="field">
18
+ <%= f.label :name_cont, I18n.t("spree.user") %><br />
19
+ <%= f.text_field :name_cont, class: 'fullwidth' %>
20
+ </div>
21
+ </div>
21
22
 
22
- <div class="seven columns">
23
- <div class="field">
24
- <%= label_tag nil, Spree.t(:title) -%><br/>
25
- <%= f.text_field :title_cont, :size => 25 -%>
26
- </div>
27
- </div>
23
+ <div class="seven columns">
24
+ <div class="field">
25
+ <%= f.label :title_cont, I18n.t("spree.title") -%><br/>
26
+ <%= f.text_field :title_cont, class: 'fullwidth' -%>
27
+ </div>
28
+ </div>
28
29
 
29
- <div class="four columns">
30
- <div class="field">
31
- <%= label_tag nil, Spree.t(:review) -%><br/>
32
- <%= f.text_field :review_cont, :size => 25 -%>
33
- </div>
34
- </div>
30
+ <div class="four columns">
31
+ <div class="field">
32
+ <%= f.label :review_cont, I18n.t("spree.review") -%><br/>
33
+ <%= f.text_field :review_cont, class: 'fullwidth' -%>
34
+ </div>
35
+ </div>
35
36
 
36
- <div class="two columns omega">
37
- <div class="field">
38
- <%= label_tag nil, Spree.t(:approval_status)-%><br/>
39
- <%= f.select :approved_eq, [[Spree.t('all'), nil], [Spree.t('approved_reviews'), true], [Spree.t('unapproved_reviews'), false]] -%>
40
- </div>
41
- </div>
37
+ <div class="two columns omega">
38
+ <div class="field">
39
+ <%= f.label :approved_eq, I18n.t("spree.approval_status")-%><br/>
40
+ <%= f.select :approved_eq, [
41
+ [I18n.t("spree.all"), nil],
42
+ [I18n.t("spree.approved_reviews"), true],
43
+ [I18n.t("spree.unapproved_reviews"), false]
44
+ ], {}, class: 'select2 fullwidth' -%>
45
+ </div>
46
+ </div>
42
47
 
43
- <div class="clear"></div>
48
+ <div class="clear"></div>
44
49
 
45
- <div class="form-buttons actions filter-actions" data-hook="admin_reviews_index_search_buttons">
46
- <%= button Spree.t(:search), 'icon-search' %>
47
- </div>
50
+ <div class="form-buttons actions filter-actions" data-hook="admin_reviews_index_search_buttons">
51
+ <%= button_tag I18n.t("spree.search") %>
52
+ </div>
48
53
  <%- end -%>
49
54
  </div>
50
55
  <%- end -%>
51
56
 
52
- <% paginate @reviews %>
57
+ <%= paginate @reviews, theme: "solidus_admin" %>
53
58
 
54
59
  <% if @reviews.any? %>
55
- <table class="index">
56
- <colgroup>
57
- <col style="width: 25%;">
58
- <col style="width: 10%;">
59
- <col style="width: 10%;">
60
- <col style="width: 20%;">
61
- <col style="width: 15%;">
62
- <col style="width: 17%;">
63
- </colgroup>
64
- <thead>
65
- <tr>
66
- <th><%= Spree.t('product') %></th>
67
- <th><%= Spree::Review.human_attribute_name(:rating) %></th>
68
- <th><%= Spree.t('feedback') %></th>
69
- <th><%= Spree::Review.human_attribute_name(:user) %></th>
70
- <th><%= Spree::Review.human_attribute_name(:created_at) %></th>
71
- </tr>
72
- </thead>
73
- <tbody>
74
- <%- @reviews.each do |review| -%>
75
- <tr id="<%= dom_id review %>">
76
- <td>
77
- <% if review.product %>
78
- <%= link_to review.product.name, product_path(review.product) %>
79
- <% end %>
80
- </td>
81
- <td class="align-center">
82
- <%= txt_stars(review.rating) %>
83
- </td>
84
- <td class="align-center">
85
- <%= link_to "(#{review.feedback_stars}/#{review.feedback_reviews.size})", admin_review_feedback_reviews_path(review) %>
86
- </td>
87
- <td class="align-center">
88
- <%= review.user_id ? link_to(review.user.try(:email), [:admin, review.user]) : Spree.t(:anonymous) %></p>
89
- <p><%= Spree::Review.human_attribute_name(:ip_address) %>: <%= review.ip_address ? link_to(review.ip_address, "http://whois.domaintools.com/#{review.ip_address}") : '-' %></p>
90
- </td>
91
- <td class="align-center">
92
- <%= l review.created_at, :format => :short %>
93
- </td>
94
- <td class="actions">
95
- <%= link_to_with_icon 'check', Spree.t('approve'), approve_admin_review_url(review), :no_text => true, class: 'approve' unless review.approved %>
96
- &nbsp;
97
- <%= link_to_edit review, :no_text => true, :class => 'edit' %>
98
- &nbsp;
99
- <%= link_to_delete review, :no_text => true %>
100
- </td>
101
- </tr>
102
- <% end %>
103
- </tbody>
104
- </table>
60
+ <table class="index">
61
+ <colgroup>
62
+ <col style="width: 20%;">
63
+ <col style="width: 10%;">
64
+ <col style="width: 10%;">
65
+ <col style="width: 15%;">
66
+ <col style="width: 15%;">
67
+ <col style="width: 15%;">
68
+ <col style="width: 17%;">
69
+ </colgroup>
70
+ <thead>
71
+ <tr>
72
+ <th><%= I18n.t("spree.product") %></th>
73
+ <th><%= "#{Spree::Review.human_attribute_name(:rating)}/#{I18n.t("spree.feedback")}" %></th>
74
+ <th><%= I18n.t("spree.verified_purchaser") %></th>
75
+ <th><%= Spree::Review.human_attribute_name(:user) %></th>
76
+ <th><%= Spree::Review.human_attribute_name(:created_at) %></th>
77
+ <th><%= Spree::Review.human_attribute_name(:images) %></th>
78
+ <th class="actions"></th>
79
+ </tr>
80
+ </thead>
81
+ <tbody>
82
+ <%- @reviews.each do |review| -%>
83
+ <tr id="<%= dom_id review %>">
84
+ <td>
85
+ <% if review.product %>
86
+ <%= link_to review.product.name, product_path(review.product) %>
87
+ <% end %>
88
+ </td>
89
+ <td class="align-center">
90
+ <%= txt_stars(review.rating) %><br />
91
+ <%= link_to "(#{review.feedback_stars}/#{review.feedback_reviews.size})", admin_review_feedback_reviews_path(review) %>
92
+ </td>
93
+ <td class="align-center">
94
+ <% if review.verified_purchaser? %>
95
+ <%= solidus_icon('fa fa-check') %>
96
+ <% end %>
97
+ </td>
98
+ <td class="align-center">
99
+ <p><%= review.user_id ? link_to(review.user.try(:email), [:admin, review.user]) : I18n.t("spree.anonymous") %></p>
100
+ <p><%= Spree::Review.human_attribute_name(:ip_address) %>: <%= review.ip_address ? link_to(review.ip_address, "http://whois.domaintools.com/#{review.ip_address}") : '-' %></p>
101
+ </td>
102
+ <td class="align-center">
103
+ <%= l review.created_at, format: :short %>
104
+ </td>
105
+ <td class="align-center">
106
+ <% review.images.each do |image| %>
107
+ <%= link_to image_tag(image.url(:product)), image.url(:original) %>
108
+ <% end %>
109
+ </td>
110
+ <td class="actions">
111
+ <% if can? :manage, Spree::Review %>
112
+ <%= link_to_with_icon 'ok', I18n.t("spree.approve"), approve_admin_review_url(review), no_text: true, class: 'approve' unless review.approved %>
113
+ <%= link_to_edit review, no_text: true, class: 'edit' %>
114
+ <%= link_to_delete review, no_text: true %>
115
+ <% end %>
116
+ </td>
117
+ </tr>
118
+ <% end %>
119
+ </tbody>
120
+ </table>
105
121
  <% else %>
106
- <div class="no-objects-found">
107
- <%= Spree.t(:no_results) %>
108
- </div>
122
+ <div class="no-objects-found">
123
+ <%= I18n.t("spree.no_results") %>
124
+ </div>
109
125
  <% end %>
110
126
 
111
- <%= paginate @reviews -%>
127
+ <%= paginate @reviews, theme: "solidus_admin" -%>
@@ -0,0 +1,5 @@
1
+ # frozen_string_literal: true
2
+
3
+ json.cache! [I18n.locale, feedback_review] do
4
+ json.call(feedback_review, *feedback_review_attributes)
5
+ end
@@ -0,0 +1,11 @@
1
+ # frozen_string_literal: true
2
+
3
+ json.cache! [I18n.locale, review] do
4
+ json.call(review, *review_attributes)
5
+ json.images(review.images) do |image|
6
+ json.partial!("spree/api/images/image", image: image)
7
+ end
8
+ json.feedback_reviews(review.feedback_reviews) do |feedback_review|
9
+ json.partial!("spree/api/reviews/feedback_review", feedback_review: feedback_review)
10
+ end
11
+ end
@@ -0,0 +1,6 @@
1
+ # frozen_string_literal: true
2
+
3
+ json.reviews(@reviews) do |review|
4
+ json.partial!("spree/api/reviews/review", review: review)
5
+ end
6
+ json.avg_rating(@product&.avg_rating)
@@ -0,0 +1,3 @@
1
+ # frozen_string_literal: true
2
+
3
+ json.partial!("spree/api/reviews/review", review: @review)
@@ -1,13 +1,13 @@
1
- <%= render 'spree/feedback_reviews/summary', :review => review %>
2
- <%= form_for((@feedback_review ||= review.feedback_reviews.build), :url => feedback_reviews_path(review), :method => :post, :remote => true) do |f| %>
1
+ <%= render 'spree/feedback_reviews/summary', review: review %>
2
+ <%= form_for((@feedback_review ||= review.feedback_reviews.build), url: feedback_reviews_path(review), method: :post, remote: true) do |f| %>
3
3
  <% unless @feedback_review.errors.empty? %>
4
4
  <span class="error"><%= @feedback_review.errors[:rating] %></span>
5
5
  <br />
6
6
  <% end %>
7
- <%= Spree.t(:was_this_review_helpful) %>
7
+ <%= I18n.t("spree.was_this_review_helpful") %>
8
8
  <% for i in 1..NB_STARS %>
9
9
  <%= radio_button_tag "feedback_review[rating]",
10
- Spree.t('star', :count => i), false, :class => "star" %>
10
+ I18n.t("spree.star", count: i), false, class: "star" %>
11
11
  <% end %>
12
- <button class="feedback-review"><span><%= Spree.t(:say_yes) %></span></button>
12
+ <button class="feedback-review"><span><%= I18n.t("spree.say_yes") %></span></button>
13
13
  <% end %>
@@ -1,6 +1,6 @@
1
1
  <p>
2
- <%= Spree.t('voice', :count => review.feedback_reviews.count) %>.
3
- <span title="<%= pluralize(review.feedback_stars, 'star') %> <%= Spree.t('out_of_5') %>">
4
- <%= render 'spree/reviews/stars', :stars => review.feedback_stars %>
2
+ <%= I18n.t('spree.voice', count: review.feedback_reviews.count) %>.
3
+ <span title="<%= pluralize(review.feedback_stars, 'star') %> <%= I18n.t('spree.out_of_5') %>">
4
+ <%= render 'spree/reviews/stars', stars: review.feedback_stars %>
5
5
  </span> &nbsp;
6
6
  </p>
@@ -1,7 +1,7 @@
1
1
  <% if @feedback_review.valid? %>
2
- $("div#feedback_review_<%= @review.id %>").html("<%= escape_javascript(render('spree/feedback_reviews/summary', :review => @review)) %>");
2
+ $("div#feedback_review_<%= @review.id %>").html("<%= escape_javascript(render('spree/feedback_reviews/summary', review: @review)) %>");
3
3
  <% else %>
4
- $("div#feedback_review_<%= @review.id %>").html("<%= escape_javascript(render('spree/feedback_reviews/form', :review => @review)) %>");
4
+ $("div#feedback_review_<%= @review.id %>").html("<%= escape_javascript(render('spree/feedback_reviews/form', review: @review)) %>");
5
5
 
6
6
  <% end %>
7
7
  $(document).ready(function(){$("div#feedback_review_<%= @review.id %>").find(".star").rating({required:true});});
@@ -1,34 +1,41 @@
1
- <%= form_for review, :url => product_reviews_path(product), :html => {:method => :post} do |f| %>
2
- <%= render "spree/shared/error_messages", :target => review %>
1
+ <%= form_for review, url: product_reviews_path(product), html: { method: :post, multipart: true} do |f| %>
2
+ <%= render "spree/shared/error_messages", target: review %>
3
3
 
4
4
  <p class="review_rating_field">
5
5
  <%= f.label :rating %> <span class="required">*</span><br />
6
- <%= render "spree/reviews/stars", :stars => review.rating, :edit_enabled => true %>
6
+ <%= render "spree/reviews/stars", stars: review.rating, edit_enabled: true %>
7
7
  </p>
8
8
 
9
9
  <p class="review_name_field">
10
- <%= f.label :name %> <span class="required">*</span><br />
11
- <%= f.text_field :name, :maxlength => "255", :size => "50" %>
10
+ <%= f.label :name %><br />
11
+ <%= f.text_field :name, maxlength: "255", size: "50" %>
12
12
  </p>
13
13
 
14
14
  <p class="review_title_field">
15
15
  <%= f.label :title %><br />
16
- <%= f.text_field :title, :maxlength => "255", :size => "50" %>
16
+ <%= f.text_field :title, maxlength: "255", size: "50" %>
17
17
  </p>
18
18
 
19
19
  <p class="review_review_field">
20
- <%= f.label :review %> <span class="required">*</span><br />
21
- <%= f.text_area :review, :wrap => "virtual", :rows => "10", :cols => "50" %>
20
+ <%= f.label :review %><br />
21
+ <%= f.text_area :review, wrap: "virtual", rows: "10", cols: "50" %>
22
22
  </p>
23
23
 
24
+ <% if Spree::Reviews::Config[:allow_image_upload] %>
25
+ <p class="review_images_field">
26
+ <%= f.label :images %><br>
27
+ <%= f.file_field :images, :accept => "image/*", multiple: true %>
28
+ </p>
29
+ <% end %>
30
+
24
31
  <% if Spree::Reviews::Config[:render_show_identifier_checkbox] %>
25
32
  <p class="review_show_identifier_field">
26
33
  <%= f.label :show_identifier %><br />
27
- <%= f.check_box :show_identifier, :wrap => "virtual", :rows => "10", :cols => "50", :checked => true %>
34
+ <%= f.check_box :show_identifier, wrap: "virtual", rows: "10", cols: "50", checked: true %>
28
35
  </p>
29
36
  <% end %>
30
37
 
31
38
  <p class="review_submit">
32
- <%= f.submit Spree.t(:submit_your_review), :class => "button bg_darkfirst" %>
39
+ <%= f.submit I18n.t("spree.submit_your_review"), class: "button bg_darkfirst" %>
33
40
  </p>
34
41
  <% end %>
@@ -0,0 +1,3 @@
1
+ <%= content_tag :h2, I18n.t("spree.leave_us_a_review_for", name: @product.name), class: 'new-review-title' %>
2
+
3
+ <%= render 'form', review: @review, product: @product %>
@@ -1,3 +1,3 @@
1
- <%= content_tag :h2, Spree.t(:leave_us_a_review_for, :name => @product.name), :class => 'new-review-title' %>
1
+ <%= content_tag :h2, I18n.t("spree.leave_us_a_review_for", name: @product.name), class: 'new-review-title' %>
2
2
 
3
- <%= render 'form', :review => @review, :product => @product %>
3
+ <%= render 'form', review: @review, product: @product %>
@@ -1,13 +1,13 @@
1
1
  <% stars = product.stars %>
2
2
  <% reviews_count = product.reviews_count %>
3
3
  <div class="ratings">
4
- <p><%= Spree.t('average_customer_rating') %>: </p>
4
+ <p><%= I18n.t('spree.average_customer_rating') %>: </p>
5
5
  <p class="ratings-stars">
6
6
  <span title="<%= txt_stars(stars) %>">
7
- <%= render 'spree/reviews/stars', :stars => stars %>
7
+ <%= render 'spree/reviews/stars', stars: stars %>
8
8
  </span>
9
9
  </p>
10
- <p class="ratings-basedupon">(<%= Spree.t('based_upon_review_count', :count => reviews_count) %>)</p>
10
+ <p class="ratings-basedupon">(<%= I18n.t('spree.based_upon_review_count', count: reviews_count) %>)</p>
11
11
  <div itemprop="aggregateRating" itemscope itemtype="http://schema.org/AggregateRating">
12
12
  <meta itemprop="ratingValue" content="<%= stars %>" />
13
13
  <meta itemprop="reviewCount" content="<%= reviews_count %>" />
@@ -1,28 +1,40 @@
1
1
  <div class="review" itemprop="reviews" itemscope itemtype="http://schema.org/Review">
2
2
  <span class="reviews-rating" title="<%= txt_stars(review.rating) %>">
3
- <%= render "spree/reviews/stars", :stars => review.rating %>
3
+ <%= render "spree/reviews/stars", stars: review.rating %>
4
4
  </span>
5
- <span itemprop="name"><%= review.title %></span>
6
- <br/>
7
- <span class="attribution"><%= Spree.t(:submitted_on) %> <strong><%= l review.created_at.to_date %></strong></span>
8
- <meta itemprop="datePublished" content="<%= review.created_at.to_date.to_s %>" />
5
+ <% if review.approved? || Spree::Reviews::Config[:display_unapproved_reviews] %>
6
+ <span itemprop="name"><%= review.title %></span>
7
+ <br/>
8
+ <span class="attribution"><%= I18n.t("spree.submitted_on") %> <strong><%= l review.created_at.to_date %></strong></span>
9
+ <meta itemprop="datePublished" content="<%= review.created_at.to_date.to_s %>" />
9
10
 
10
- <meta itemprop="reviewRating" content="<%= review.rating %>" />
11
- <% if review.show_identifier %>
12
- <% if Spree::Reviews::Config[:show_email] && review.user %>
13
- <span itemprop="author"><%= review.user.email %></span>
11
+ <meta itemprop="reviewRating" content="<%= review.rating %>" />
12
+ <% if review.show_identifier %>
13
+ <% if Spree::Reviews::Config[:show_email] && review.user %>
14
+ <span itemprop="author"><%= review.user.email %></span>
15
+ <% else %>
16
+ <span itemprop="author"><%= review.name %></span>
17
+ <% end %>
14
18
  <% else %>
15
- <span itemprop="author"><%= review.name %></span>
19
+ <span itemprop="author"><%= I18n.t("spree.anonymous") %></span>
16
20
  <% end %>
17
- <% else %>
18
- <span itemprop="author"><%= Spree.t(:anonymous) %></span>
19
- <% end %>
20
- <div itemprop="reviewBody">
21
- <%= simple_format(review.review) %>
22
- </div>
23
- <% if Spree::Reviews::Config[:feedback_rating] && (!Spree::Reviews::Config[:require_login] || spree_current_user) %>
24
- <div class="feedback_review" id="feedback_review_<%= review.id %>">
25
- <%= render "spree/feedback_reviews/form", :review => review %>
21
+ <% if Spree::Reviews::Config[:show_verified_purchaser] && review.verified_purchaser? %>
22
+ <div><%= I18n.t("spree.verified_purchaser") %></div>
23
+ <% end %>
24
+ <div itemprop="reviewBody">
25
+ <%= simple_format(review.review) %>
26
26
  </div>
27
+ <% if Spree::Reviews::Config[:allow_image_upload] %>
28
+ <% review.images.each do |image| %>
29
+ <div itemprop="image">
30
+ <%= link_to image_tag(image.url(:product)), image.url(:original) %>
31
+ </div>
32
+ <% end %>
33
+ <% end %>
34
+ <% if Spree::Reviews::Config[:feedback_rating] && (!Spree::Reviews::Config[:require_login] || spree_current_user) %>
35
+ <div class="feedback_review" id="feedback_review_<%= review.id %>">
36
+ <%= render "spree/feedback_reviews/form", review: review %>
37
+ </div>
38
+ <% end %>
27
39
  <% end %>
28
40
  </div>