spree_frontend 3.1.14 → 3.2.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/assets/images/logo/spree_50.png +0 -0
- data/app/assets/javascripts/spree/frontend/cart.js.coffee +14 -1
- data/app/assets/javascripts/spree/frontend/checkout/payment.js.coffee +11 -35
- data/app/assets/javascripts/spree/frontend/checkout/shipment.js.coffee +38 -0
- data/app/assets/javascripts/spree/frontend/coupon_manager.js.coffee +37 -0
- data/app/assets/stylesheets/spree/frontend/frontend_bootstrap.css.scss +3 -3
- data/app/controllers/spree/checkout_controller.rb +0 -14
- data/app/controllers/spree/content_controller.rb +3 -3
- data/app/controllers/spree/orders_controller.rb +7 -2
- data/app/controllers/spree/products_controller.rb +3 -2
- data/app/controllers/spree/store_controller.rb +0 -18
- data/app/helpers/spree/frontend_helper.rb +1 -1
- data/app/helpers/spree/orders_helper.rb +0 -9
- data/app/views/kaminari/twitter-bootstrap-3/_first_page.html.erb +1 -1
- data/app/views/kaminari/twitter-bootstrap-3/_last_page.html.erb +1 -1
- data/app/views/kaminari/twitter-bootstrap-3/_next_page.html.erb +1 -1
- data/app/views/kaminari/twitter-bootstrap-3/_page.html.erb +1 -1
- data/app/views/kaminari/twitter-bootstrap-3/_prev_page.html.erb +1 -1
- data/app/views/spree/address/_form.html.erb +16 -16
- data/app/views/spree/checkout/_address.html.erb +4 -4
- data/app/views/spree/checkout/_confirm.html.erb +2 -2
- data/app/views/spree/checkout/_delivery.html.erb +5 -3
- data/app/views/spree/checkout/_payment.html.erb +3 -3
- data/app/views/spree/checkout/_summary.html.erb +3 -3
- data/app/views/spree/checkout/edit.html.erb +1 -0
- data/app/views/spree/checkout/payment/_gateway.html.erb +8 -8
- data/app/views/spree/home/index.html.erb +3 -2
- data/app/views/spree/orders/_adjustment_row.html.erb +1 -1
- data/app/views/spree/orders/_adjustments.html.erb +3 -3
- data/app/views/spree/orders/edit.html.erb +15 -2
- data/app/views/spree/products/_properties.html.erb +1 -1
- data/app/views/spree/products/index.html.erb +5 -5
- data/app/views/spree/products/show.html.erb +6 -6
- data/app/views/spree/shared/_address.html.erb +3 -1
- data/app/views/spree/shared/_error_messages.html.erb +1 -1
- data/app/views/spree/shared/_filters.html.erb +2 -2
- data/app/views/spree/shared/_google_add_items.js.erb +5 -5
- data/app/views/spree/shared/_head.html.erb +2 -0
- data/app/views/spree/shared/_header.html.erb +2 -2
- data/app/views/spree/shared/_login.html.erb +4 -4
- data/app/views/spree/shared/_nav_bar.html.erb +1 -1
- data/app/views/spree/shared/_order_details.html.erb +2 -2
- data/app/views/spree/shared/_search.html.erb +3 -3
- data/app/views/spree/shared/_translations.html.erb +7 -0
- data/config/initializers/assets.rb +1 -1
- data/config/routes.rb +1 -6
- data/lib/tasks/taxon.rake +2 -2
- data/spec/controllers/controller_extension_spec.rb +126 -0
- data/spec/controllers/controller_helpers_spec.rb +122 -0
- data/spec/controllers/spree/checkout_controller_spec.rb +462 -0
- data/spec/controllers/spree/checkout_controller_with_views_spec.rb +36 -0
- data/spec/controllers/spree/content_controller_spec.rb +12 -0
- data/spec/controllers/spree/current_order_tracking_spec.rb +44 -0
- data/spec/controllers/spree/home_controller_spec.rb +47 -0
- data/spec/controllers/spree/orders_controller_ability_spec.rb +96 -0
- data/spec/controllers/spree/orders_controller_spec.rb +134 -0
- data/spec/controllers/spree/orders_controller_transitions_spec.rb +31 -0
- data/spec/controllers/spree/products_controller_spec.rb +87 -0
- data/spec/controllers/spree/taxons_controller_spec.rb +12 -0
- data/spec/features/address_spec.rb +93 -0
- data/spec/features/automatic_promotion_adjustments_spec.rb +47 -0
- data/spec/features/caching/products_spec.rb +59 -0
- data/spec/features/caching/taxons_spec.rb +22 -0
- data/spec/features/cart_spec.rb +132 -0
- data/spec/features/checkout_spec.rb +572 -0
- data/spec/features/checkout_unshippable_spec.rb +34 -0
- data/spec/features/coupon_code_spec.rb +88 -0
- data/spec/features/currency_spec.rb +18 -0
- data/spec/features/delivery_spec.rb +64 -0
- data/spec/features/free_shipping_promotions_spec.rb +59 -0
- data/spec/features/locale_spec.rb +60 -0
- data/spec/features/microdata_spec.rb +0 -0
- data/spec/features/order_spec.rb +107 -0
- data/spec/features/page_promotions_spec.rb +36 -0
- data/spec/features/products_spec.rb +334 -0
- data/spec/features/taxons_spec.rb +147 -0
- data/spec/features/template_rendering_spec.rb +19 -0
- data/spec/helpers/frontend_helper_spec.rb +57 -0
- data/spec/helpers/taxons_helper_spec.rb +17 -0
- data/spec/spec_helper.rb +126 -0
- data/spec/support/shared_contexts/checkout_setup.rb +10 -0
- data/spec/support/shared_contexts/custom_products.rb +25 -0
- data/spec/support/shared_contexts/product_prototypes.rb +30 -0
- data/spec/views/spree/checkout/_summary_spec.rb +11 -0
- data/spree_frontend.gemspec +6 -3
- metadata +92 -263
- data/app/assets/images/flags/ad.png +0 -0
- data/app/assets/images/flags/ae.png +0 -0
- data/app/assets/images/flags/af.png +0 -0
- data/app/assets/images/flags/ag.png +0 -0
- data/app/assets/images/flags/ai.png +0 -0
- data/app/assets/images/flags/al.png +0 -0
- data/app/assets/images/flags/am.png +0 -0
- data/app/assets/images/flags/an.png +0 -0
- data/app/assets/images/flags/ao.png +0 -0
- data/app/assets/images/flags/ar.png +0 -0
- data/app/assets/images/flags/as.png +0 -0
- data/app/assets/images/flags/at.png +0 -0
- data/app/assets/images/flags/au.png +0 -0
- data/app/assets/images/flags/aw.png +0 -0
- data/app/assets/images/flags/ax.png +0 -0
- data/app/assets/images/flags/az.png +0 -0
- data/app/assets/images/flags/ba.png +0 -0
- data/app/assets/images/flags/bb.png +0 -0
- data/app/assets/images/flags/bd.png +0 -0
- data/app/assets/images/flags/be.png +0 -0
- data/app/assets/images/flags/bf.png +0 -0
- data/app/assets/images/flags/bg.png +0 -0
- data/app/assets/images/flags/bh.png +0 -0
- data/app/assets/images/flags/bi.png +0 -0
- data/app/assets/images/flags/bj.png +0 -0
- data/app/assets/images/flags/bm.png +0 -0
- data/app/assets/images/flags/bn.png +0 -0
- data/app/assets/images/flags/bo.png +0 -0
- data/app/assets/images/flags/br.png +0 -0
- data/app/assets/images/flags/bs.png +0 -0
- data/app/assets/images/flags/bt.png +0 -0
- data/app/assets/images/flags/bv.png +0 -0
- data/app/assets/images/flags/bw.png +0 -0
- data/app/assets/images/flags/by.png +0 -0
- data/app/assets/images/flags/bz.png +0 -0
- data/app/assets/images/flags/ca.png +0 -0
- data/app/assets/images/flags/catalonia.png +0 -0
- data/app/assets/images/flags/cc.png +0 -0
- data/app/assets/images/flags/cd.png +0 -0
- data/app/assets/images/flags/cf.png +0 -0
- data/app/assets/images/flags/cg.png +0 -0
- data/app/assets/images/flags/ch.png +0 -0
- data/app/assets/images/flags/ci.png +0 -0
- data/app/assets/images/flags/ck.png +0 -0
- data/app/assets/images/flags/cl.png +0 -0
- data/app/assets/images/flags/cm.png +0 -0
- data/app/assets/images/flags/cn.png +0 -0
- data/app/assets/images/flags/co.png +0 -0
- data/app/assets/images/flags/cr.png +0 -0
- data/app/assets/images/flags/cs.png +0 -0
- data/app/assets/images/flags/cu.png +0 -0
- data/app/assets/images/flags/cv.png +0 -0
- data/app/assets/images/flags/cx.png +0 -0
- data/app/assets/images/flags/cy.png +0 -0
- data/app/assets/images/flags/cz.png +0 -0
- data/app/assets/images/flags/de.png +0 -0
- data/app/assets/images/flags/dj.png +0 -0
- data/app/assets/images/flags/dk.png +0 -0
- data/app/assets/images/flags/dm.png +0 -0
- data/app/assets/images/flags/do.png +0 -0
- data/app/assets/images/flags/dz.png +0 -0
- data/app/assets/images/flags/ec.png +0 -0
- data/app/assets/images/flags/ee.png +0 -0
- data/app/assets/images/flags/eg.png +0 -0
- data/app/assets/images/flags/eh.png +0 -0
- data/app/assets/images/flags/england.png +0 -0
- data/app/assets/images/flags/er.png +0 -0
- data/app/assets/images/flags/es.png +0 -0
- data/app/assets/images/flags/et.png +0 -0
- data/app/assets/images/flags/europeanunion.png +0 -0
- data/app/assets/images/flags/fam.png +0 -0
- data/app/assets/images/flags/fi.png +0 -0
- data/app/assets/images/flags/fj.png +0 -0
- data/app/assets/images/flags/fk.png +0 -0
- data/app/assets/images/flags/fm.png +0 -0
- data/app/assets/images/flags/fo.png +0 -0
- data/app/assets/images/flags/fr.png +0 -0
- data/app/assets/images/flags/ga.png +0 -0
- data/app/assets/images/flags/gb.png +0 -0
- data/app/assets/images/flags/gd.png +0 -0
- data/app/assets/images/flags/ge.png +0 -0
- data/app/assets/images/flags/gf.png +0 -0
- data/app/assets/images/flags/gh.png +0 -0
- data/app/assets/images/flags/gi.png +0 -0
- data/app/assets/images/flags/gl.png +0 -0
- data/app/assets/images/flags/gm.png +0 -0
- data/app/assets/images/flags/gn.png +0 -0
- data/app/assets/images/flags/gp.png +0 -0
- data/app/assets/images/flags/gq.png +0 -0
- data/app/assets/images/flags/gr.png +0 -0
- data/app/assets/images/flags/gs.png +0 -0
- data/app/assets/images/flags/gt.png +0 -0
- data/app/assets/images/flags/gu.png +0 -0
- data/app/assets/images/flags/gw.png +0 -0
- data/app/assets/images/flags/gy.png +0 -0
- data/app/assets/images/flags/hk.png +0 -0
- data/app/assets/images/flags/hm.png +0 -0
- data/app/assets/images/flags/hn.png +0 -0
- data/app/assets/images/flags/hr.png +0 -0
- data/app/assets/images/flags/ht.png +0 -0
- data/app/assets/images/flags/hu.png +0 -0
- data/app/assets/images/flags/id.png +0 -0
- data/app/assets/images/flags/ie.png +0 -0
- data/app/assets/images/flags/il.png +0 -0
- data/app/assets/images/flags/in.png +0 -0
- data/app/assets/images/flags/io.png +0 -0
- data/app/assets/images/flags/iq.png +0 -0
- data/app/assets/images/flags/ir.png +0 -0
- data/app/assets/images/flags/is.png +0 -0
- data/app/assets/images/flags/it.png +0 -0
- data/app/assets/images/flags/ja.png +0 -0
- data/app/assets/images/flags/jm.png +0 -0
- data/app/assets/images/flags/jo.png +0 -0
- data/app/assets/images/flags/ke.png +0 -0
- data/app/assets/images/flags/kg.png +0 -0
- data/app/assets/images/flags/kh.png +0 -0
- data/app/assets/images/flags/ki.png +0 -0
- data/app/assets/images/flags/km.png +0 -0
- data/app/assets/images/flags/kn.png +0 -0
- data/app/assets/images/flags/kp.png +0 -0
- data/app/assets/images/flags/kr.png +0 -0
- data/app/assets/images/flags/kw.png +0 -0
- data/app/assets/images/flags/ky.png +0 -0
- data/app/assets/images/flags/kz.png +0 -0
- data/app/assets/images/flags/la.png +0 -0
- data/app/assets/images/flags/lb.png +0 -0
- data/app/assets/images/flags/lc.png +0 -0
- data/app/assets/images/flags/li.png +0 -0
- data/app/assets/images/flags/lk.png +0 -0
- data/app/assets/images/flags/lr.png +0 -0
- data/app/assets/images/flags/ls.png +0 -0
- data/app/assets/images/flags/lt.png +0 -0
- data/app/assets/images/flags/lu.png +0 -0
- data/app/assets/images/flags/lv.png +0 -0
- data/app/assets/images/flags/ly.png +0 -0
- data/app/assets/images/flags/ma.png +0 -0
- data/app/assets/images/flags/mc.png +0 -0
- data/app/assets/images/flags/md.png +0 -0
- data/app/assets/images/flags/me.png +0 -0
- data/app/assets/images/flags/mg.png +0 -0
- data/app/assets/images/flags/mh.png +0 -0
- data/app/assets/images/flags/mk.png +0 -0
- data/app/assets/images/flags/ml.png +0 -0
- data/app/assets/images/flags/mm.png +0 -0
- data/app/assets/images/flags/mn.png +0 -0
- data/app/assets/images/flags/mo.png +0 -0
- data/app/assets/images/flags/mp.png +0 -0
- data/app/assets/images/flags/mq.png +0 -0
- data/app/assets/images/flags/mr.png +0 -0
- data/app/assets/images/flags/ms.png +0 -0
- data/app/assets/images/flags/mt.png +0 -0
- data/app/assets/images/flags/mu.png +0 -0
- data/app/assets/images/flags/mv.png +0 -0
- data/app/assets/images/flags/mw.png +0 -0
- data/app/assets/images/flags/mx.png +0 -0
- data/app/assets/images/flags/my.png +0 -0
- data/app/assets/images/flags/mz.png +0 -0
- data/app/assets/images/flags/na.png +0 -0
- data/app/assets/images/flags/nc.png +0 -0
- data/app/assets/images/flags/ne.png +0 -0
- data/app/assets/images/flags/nf.png +0 -0
- data/app/assets/images/flags/ng.png +0 -0
- data/app/assets/images/flags/ni.png +0 -0
- data/app/assets/images/flags/nl.png +0 -0
- data/app/assets/images/flags/no.png +0 -0
- data/app/assets/images/flags/np.png +0 -0
- data/app/assets/images/flags/nr.png +0 -0
- data/app/assets/images/flags/nu.png +0 -0
- data/app/assets/images/flags/nz.png +0 -0
- data/app/assets/images/flags/om.png +0 -0
- data/app/assets/images/flags/pa.png +0 -0
- data/app/assets/images/flags/pe.png +0 -0
- data/app/assets/images/flags/pf.png +0 -0
- data/app/assets/images/flags/pg.png +0 -0
- data/app/assets/images/flags/ph.png +0 -0
- data/app/assets/images/flags/pk.png +0 -0
- data/app/assets/images/flags/pl.png +0 -0
- data/app/assets/images/flags/pm.png +0 -0
- data/app/assets/images/flags/pn.png +0 -0
- data/app/assets/images/flags/pr.png +0 -0
- data/app/assets/images/flags/ps.png +0 -0
- data/app/assets/images/flags/pt.png +0 -0
- data/app/assets/images/flags/pw.png +0 -0
- data/app/assets/images/flags/py.png +0 -0
- data/app/assets/images/flags/qa.png +0 -0
- data/app/assets/images/flags/re.png +0 -0
- data/app/assets/images/flags/ro.png +0 -0
- data/app/assets/images/flags/rs.png +0 -0
- data/app/assets/images/flags/ru.png +0 -0
- data/app/assets/images/flags/rw.png +0 -0
- data/app/assets/images/flags/sa.png +0 -0
- data/app/assets/images/flags/sb.png +0 -0
- data/app/assets/images/flags/sc.png +0 -0
- data/app/assets/images/flags/scotland.png +0 -0
- data/app/assets/images/flags/sd.png +0 -0
- data/app/assets/images/flags/se.png +0 -0
- data/app/assets/images/flags/sg.png +0 -0
- data/app/assets/images/flags/sh.png +0 -0
- data/app/assets/images/flags/si.png +0 -0
- data/app/assets/images/flags/sj.png +0 -0
- data/app/assets/images/flags/sk.png +0 -0
- data/app/assets/images/flags/sl.png +0 -0
- data/app/assets/images/flags/sm.png +0 -0
- data/app/assets/images/flags/sn.png +0 -0
- data/app/assets/images/flags/so.png +0 -0
- data/app/assets/images/flags/sr.png +0 -0
- data/app/assets/images/flags/st.png +0 -0
- data/app/assets/images/flags/sv.png +0 -0
- data/app/assets/images/flags/sy.png +0 -0
- data/app/assets/images/flags/sz.png +0 -0
- data/app/assets/images/flags/tc.png +0 -0
- data/app/assets/images/flags/td.png +0 -0
- data/app/assets/images/flags/tf.png +0 -0
- data/app/assets/images/flags/tg.png +0 -0
- data/app/assets/images/flags/th.png +0 -0
- data/app/assets/images/flags/tj.png +0 -0
- data/app/assets/images/flags/tk.png +0 -0
- data/app/assets/images/flags/tl.png +0 -0
- data/app/assets/images/flags/tm.png +0 -0
- data/app/assets/images/flags/tn.png +0 -0
- data/app/assets/images/flags/to.png +0 -0
- data/app/assets/images/flags/tr.png +0 -0
- data/app/assets/images/flags/tt.png +0 -0
- data/app/assets/images/flags/tv.png +0 -0
- data/app/assets/images/flags/tw.png +0 -0
- data/app/assets/images/flags/tz.png +0 -0
- data/app/assets/images/flags/ua.png +0 -0
- data/app/assets/images/flags/ug.png +0 -0
- data/app/assets/images/flags/um.png +0 -0
- data/app/assets/images/flags/us.png +0 -0
- data/app/assets/images/flags/uy.png +0 -0
- data/app/assets/images/flags/uz.png +0 -0
- data/app/assets/images/flags/va.png +0 -0
- data/app/assets/images/flags/vc.png +0 -0
- data/app/assets/images/flags/ve.png +0 -0
- data/app/assets/images/flags/vg.png +0 -0
- data/app/assets/images/flags/vi.png +0 -0
- data/app/assets/images/flags/vn.png +0 -0
- data/app/assets/images/flags/vu.png +0 -0
- data/app/assets/images/flags/wales.png +0 -0
- data/app/assets/images/flags/wf.png +0 -0
- data/app/assets/images/flags/ws.png +0 -0
- data/app/assets/images/flags/ye.png +0 -0
- data/app/assets/images/flags/yt.png +0 -0
- data/app/assets/images/flags/za.png +0 -0
- data/app/assets/images/flags/zm.png +0 -0
- data/app/assets/images/flags/zw.png +0 -0
- data/app/assets/images/spree_header.jpg +0 -0
- data/app/views/spree/products/_image.html.erb +0 -5
@@ -6,7 +6,7 @@
|
|
6
6
|
<h3 class="panel-title"><%= Spree.t(:billing_address) %></h3>
|
7
7
|
</div>
|
8
8
|
<div class="panel-body">
|
9
|
-
<%= render :
|
9
|
+
<%= render partial: 'spree/address/form', locals: { form: bill_form, address_type: 'billing', address: @order.bill_address } %>
|
10
10
|
</div>
|
11
11
|
<% end %>
|
12
12
|
</div>
|
@@ -20,12 +20,12 @@
|
|
20
20
|
</div>
|
21
21
|
<div class="panel-body">
|
22
22
|
<p class="field checkbox" data-hook="use_billing">
|
23
|
-
<%= label_tag :order_use_billing, :
|
23
|
+
<%= label_tag :order_use_billing, id: 'use_billing' do %>
|
24
24
|
<%= check_box_tag 'order[use_billing]', '1', @order.shipping_eq_billing_address? %>
|
25
25
|
<%= Spree.t(:use_billing_address) %>
|
26
26
|
<% end %>
|
27
27
|
</p>
|
28
|
-
<%= render :
|
28
|
+
<%= render partial: 'spree/address/form', locals: { form: ship_form, address_type: 'shipping', address: @order.ship_address } %>
|
29
29
|
</div>
|
30
30
|
<% end %>
|
31
31
|
</div>
|
@@ -33,7 +33,7 @@
|
|
33
33
|
</div>
|
34
34
|
|
35
35
|
<div class="well text-right form-buttons" data-hook="buttons">
|
36
|
-
<%= submit_tag Spree.t(:save_and_continue), :
|
36
|
+
<%= submit_tag Spree.t(:save_and_continue), class: 'btn btn-lg btn-success' %>
|
37
37
|
<% if try_spree_current_user %>
|
38
38
|
<span data-hook="save_user_address">
|
39
39
|
|
@@ -3,11 +3,11 @@
|
|
3
3
|
<h3 class="panel-title"><%= Spree.t(:confirm) %></h3>
|
4
4
|
</div>
|
5
5
|
<div class="panel-body">
|
6
|
-
<%= render :
|
6
|
+
<%= render partial: 'spree/shared/order_details', locals: { order: @order } %>
|
7
7
|
</div>
|
8
8
|
</div>
|
9
9
|
|
10
10
|
<div class="well text-right form-buttons" data-hook="buttons">
|
11
|
-
<%= submit_tag Spree.t(:place_order), :
|
11
|
+
<%= submit_tag Spree.t(:place_order), class: 'btn btn-lg btn-success' %>
|
12
12
|
<script>Spree.disableSaveOnClick();</script>
|
13
13
|
</div>
|
@@ -43,7 +43,7 @@
|
|
43
43
|
<% ship_form.object.shipping_rates.each do |rate| %>
|
44
44
|
<li class="list-group-item shipping-method">
|
45
45
|
<label>
|
46
|
-
<%= ship_form.radio_button :selected_shipping_rate_id, rate.id %>
|
46
|
+
<%= ship_form.radio_button :selected_shipping_rate_id, rate.id, data: { behavior: 'shipping-method-selector', cost: rate.display_cost } %>
|
47
47
|
<span class="rate-name"><%= rate.name %></span>
|
48
48
|
<span class="badge rate-cost"><%= rate.display_cost %></span>
|
49
49
|
</label>
|
@@ -88,7 +88,7 @@
|
|
88
88
|
<% if Spree::Config[:shipping_instructions] %>
|
89
89
|
<p id="minstrs" data-hook>
|
90
90
|
<h4><%= Spree.t(:shipping_instructions) %></h4>
|
91
|
-
<%= form.text_area :special_instructions, :
|
91
|
+
<%= form.text_area :special_instructions, cols: 40, rows: 4, class: "form-control" %>
|
92
92
|
</p>
|
93
93
|
<% end %>
|
94
94
|
</div>
|
@@ -97,5 +97,7 @@
|
|
97
97
|
<br />
|
98
98
|
|
99
99
|
<div class="well text-right form-buttons" data-hook="buttons">
|
100
|
-
<%= submit_tag Spree.t(:save_and_continue), :
|
100
|
+
<%= submit_tag Spree.t(:save_and_continue), class: 'btn btn-lg btn-success' %>
|
101
101
|
</div>
|
102
|
+
|
103
|
+
<%= javascript_include_tag 'spree/frontend/checkout/shipment' %>
|
@@ -42,7 +42,7 @@
|
|
42
42
|
<li class="list-group-item">
|
43
43
|
<label>
|
44
44
|
<%= radio_button_tag "order[payments_attributes][][payment_method_id]", method.id, method == @order.available_payment_methods.first %>
|
45
|
-
<%= Spree.t(method.name, :
|
45
|
+
<%= Spree.t(method.name, scope: :payment_methods, default: method.name) %>
|
46
46
|
</label>
|
47
47
|
</li>
|
48
48
|
<% end %>
|
@@ -52,7 +52,7 @@
|
|
52
52
|
<% @order.available_payment_methods.each do |method| %>
|
53
53
|
<li id="payment_method_<%= method.id %>" class="<%= 'last' if method == @order.available_payment_methods.last %>" data-hook>
|
54
54
|
<fieldset>
|
55
|
-
<%= render :
|
55
|
+
<%= render partial: "spree/checkout/payment/#{method.method_type}", locals: { payment_method: method } %>
|
56
56
|
</fieldset>
|
57
57
|
</li>
|
58
58
|
<% end %>
|
@@ -60,7 +60,7 @@
|
|
60
60
|
|
61
61
|
<p class='field' data-hook='coupon_code'>
|
62
62
|
<%= form.label :coupon_code %>
|
63
|
-
<%= form.text_field :coupon_code, :
|
63
|
+
<%= form.text_field :coupon_code, class: 'form-control' %>
|
64
64
|
</p>
|
65
65
|
</div>
|
66
66
|
</div>
|
@@ -27,10 +27,10 @@
|
|
27
27
|
<% end %>
|
28
28
|
</tbody>
|
29
29
|
|
30
|
-
<% if order.passed_checkout_step?("
|
30
|
+
<% if order.passed_checkout_step?("address") && order.shipments.any? %>
|
31
31
|
<tr data-hook="shipping_total">
|
32
32
|
<td><%= Spree.t(:shipping_total) %>:</td>
|
33
|
-
<td
|
33
|
+
<td data-hook='shipping-total' data-currency=<%= Money::Currency.find(order.currency).symbol %>><%= Spree::Money.new(order.shipments.to_a.sum(&:cost), currency: order.currency).to_html %></td>
|
34
34
|
</tr>
|
35
35
|
|
36
36
|
<% if order.shipment_adjustments.nonzero.exists? %>
|
@@ -59,7 +59,7 @@
|
|
59
59
|
|
60
60
|
<tr data-hook="order_total">
|
61
61
|
<td><strong><%= Spree.t(:order_total) %>:</strong></td>
|
62
|
-
<td><strong><span id='summary-order-total' class="lead text-primary"
|
62
|
+
<td><strong><span id='summary-order-total' class="lead text-primary" data-currency=<%= Money::Currency.find(order.currency).symbol %>><%= order.display_total.to_html %></span></strong></td>
|
63
63
|
</tr>
|
64
64
|
|
65
65
|
<% if order.using_store_credit? %>
|
@@ -1,20 +1,20 @@
|
|
1
1
|
<div class="well clearfix">
|
2
|
-
<%= image_tag 'credit_cards/credit_card.gif', :
|
2
|
+
<%= image_tag 'credit_cards/credit_card.gif', id: 'credit-card-image', class: 'pull-right', width: '170', height: '28' %>
|
3
3
|
<% param_prefix = "payment_source[#{payment_method.id}]" %>
|
4
4
|
|
5
5
|
<p class="field">
|
6
6
|
<%= label_tag "name_on_card_#{payment_method.id}" do %>
|
7
7
|
<%= Spree.t(:name_on_card) %><abbr class="required" title="required">*</abbr>
|
8
8
|
<% end %>
|
9
|
-
<%= text_field_tag "#{param_prefix}[name]", "#{@order.bill_address_firstname} #{@order.bill_address_lastname}", { id: "name_on_card_#{payment_method.id}", :
|
9
|
+
<%= text_field_tag "#{param_prefix}[name]", "#{@order.bill_address_firstname} #{@order.bill_address_lastname}", { id: "name_on_card_#{payment_method.id}", class: 'form-control required'} %>
|
10
10
|
</p>
|
11
11
|
|
12
12
|
<p class="field" data-hook="card_number">
|
13
13
|
<%= label_tag "card_number" do %>
|
14
14
|
<%= Spree.t(:card_number) %><abbr class="required" title="required">*</abbr>
|
15
15
|
<% end %>
|
16
|
-
<% options_hash = Rails.env.production? ? {:
|
17
|
-
<%= text_field_tag "#{param_prefix}[number]", '', options_hash.merge(:
|
16
|
+
<% options_hash = Rails.env.production? ? {autocomplete: 'off'} : {} %>
|
17
|
+
<%= text_field_tag "#{param_prefix}[number]", '', options_hash.merge(id: 'card_number', class: 'form-control required cardNumber', size: 19, maxlength: 19, autocomplete: "off") %>
|
18
18
|
|
19
19
|
<span id="card_type" style="display:none;">
|
20
20
|
( <span id="looks_like" ><%= Spree.t(:card_type_is) %> <span id="type"></span></span>
|
@@ -27,16 +27,16 @@
|
|
27
27
|
<%= label_tag "card_expiry" do %>
|
28
28
|
<%= Spree.t(:expiration) %><abbr class="required" title="required">*</abbr>
|
29
29
|
<% end %>
|
30
|
-
<%= text_field_tag "#{param_prefix}[expiry]", '', :
|
30
|
+
<%= text_field_tag "#{param_prefix}[expiry]", '', id: 'card_expiry', class: "form-control required cardExpiry", placeholder: "MM / YY" %>
|
31
31
|
</div>
|
32
32
|
<div class="col-md-4 field" data-hook="card_code">
|
33
33
|
<%= label_tag "card_code" do %>
|
34
34
|
<%= Spree.t(:card_code) %><abbr class="required" title="required">*</abbr>
|
35
35
|
<% end %>
|
36
|
-
<%= text_field_tag "#{param_prefix}[verification_value]", '', options_hash.merge(:
|
37
|
-
<%= link_to "(#{Spree.t(:what_is_this)})", spree.content_path('cvv'), :
|
36
|
+
<%= text_field_tag "#{param_prefix}[verification_value]", '', options_hash.merge(id: 'card_code', class: 'form-control required cardCode', size: 5) %>
|
37
|
+
<%= link_to "(#{Spree.t(:what_is_this)})", spree.content_path('cvv'), target: '_blank', "data-hook" => "cvv_link", id: "cvv_link" %>
|
38
38
|
</div>
|
39
39
|
</div>
|
40
40
|
|
41
|
-
<%= hidden_field_tag "#{param_prefix}[cc_type]", '', :
|
41
|
+
<%= hidden_field_tag "#{param_prefix}[cc_type]", '', id: "cc_type", class: 'ccType' %>
|
42
42
|
</div>
|
@@ -1,12 +1,13 @@
|
|
1
|
+
<% @body_id = 'home-page' %>
|
1
2
|
<% content_for :sidebar do %>
|
2
3
|
<div data-hook="homepage_sidebar_navigation">
|
3
|
-
<%= render :
|
4
|
+
<%= render partial: 'spree/shared/taxonomies' %>
|
4
5
|
</div>
|
5
6
|
<% end %>
|
6
7
|
|
7
8
|
<div data-hook="homepage_products">
|
8
9
|
<% cache(cache_key_for_products) do %>
|
9
|
-
<%= render :
|
10
|
+
<%= render partial: 'spree/shared/products', locals: { products: @products } %>
|
10
11
|
<% end %>
|
11
12
|
</div>
|
12
13
|
|
@@ -2,7 +2,7 @@
|
|
2
2
|
<tr class="adjustment">
|
3
3
|
<td colspan="4" align='right'><h5><%= type %>: <%= label %></h5></td>
|
4
4
|
<td colspan='2'>
|
5
|
-
<h5><%= Spree::Money.new(adjustments.sum(&:amount), :
|
5
|
+
<h5><%= Spree::Money.new(adjustments.sum(&:amount), currency: @order.currency) %></h5>
|
6
6
|
</td>
|
7
7
|
</tr>
|
8
8
|
<% end %>
|
@@ -6,12 +6,12 @@
|
|
6
6
|
<tbody id="cart_adjustments" data-hook>
|
7
7
|
<% if @order.line_item_adjustments.exists? %>
|
8
8
|
<% @order.line_item_adjustments.promotion.eligible.group_by(&:label).each do |label, adjustments| %>
|
9
|
-
<%= render "spree/orders/adjustment_row", :
|
9
|
+
<%= render "spree/orders/adjustment_row", label: label, adjustments: adjustments, type: Spree.t(:promotion) %>
|
10
10
|
<% end %>
|
11
11
|
<% end %>
|
12
12
|
|
13
13
|
<% @order.all_adjustments.tax.eligible.group_by(&:label).each do |label, adjustments| %>
|
14
|
-
<%= render "spree/orders/adjustment_row", :
|
14
|
+
<%= render "spree/orders/adjustment_row", label: label, adjustments: adjustments, type: Spree.t(:tax) %>
|
15
15
|
<% end %>
|
16
16
|
|
17
17
|
<% @order.shipments.each do |shipment| %>
|
@@ -24,6 +24,6 @@
|
|
24
24
|
<% end %>
|
25
25
|
|
26
26
|
<% @order.adjustments.eligible.group_by(&:label).each do |label, adjustments| %>
|
27
|
-
<%= render "spree/orders/adjustment_row", :
|
27
|
+
<%= render "spree/orders/adjustment_row", label: label, adjustments: adjustments, type: Spree.t(:adjustment) %>
|
28
28
|
<% end %>
|
29
29
|
</tbody>
|
@@ -16,7 +16,7 @@
|
|
16
16
|
<%= render partial: 'form', locals: { order_form: order_form } %>
|
17
17
|
</div>
|
18
18
|
|
19
|
-
<div class="links col-md-
|
19
|
+
<div class="links col-md-3 navbar-form pull-right text-right" data-hook="cart_buttons">
|
20
20
|
<div class="form-group">
|
21
21
|
<%= button_tag class: 'btn btn-primary', id: 'update-button' do %>
|
22
22
|
<%= Spree.t(:update) %>
|
@@ -26,11 +26,19 @@
|
|
26
26
|
<% end %>
|
27
27
|
</div>
|
28
28
|
</div>
|
29
|
+
|
30
|
+
<div class='col-md-6 form-inline pull-right' data-hook='coupon_code'>
|
31
|
+
<label>
|
32
|
+
<%= order_form.label :coupon_code %>
|
33
|
+
<%= order_form.text_field :coupon_code, size: '30', class: 'form-control' %>
|
34
|
+
<%= button_tag Spree.t(:coupon_code_apply), class: 'btn btn-default' %>
|
35
|
+
</label>
|
36
|
+
</div>
|
29
37
|
</div>
|
30
38
|
<% end %>
|
31
39
|
</div>
|
32
40
|
|
33
|
-
<div id="empty-cart" class="col-md-
|
41
|
+
<div id="empty-cart" class="col-md-3 pull-left" data-hook>
|
34
42
|
<%= form_tag empty_cart_path, method: :put do %>
|
35
43
|
<p id="clear_cart_link" data-hook>
|
36
44
|
<%= submit_tag Spree.t(:empty_cart), class: 'btn btn-default' %>
|
@@ -41,3 +49,8 @@
|
|
41
49
|
</div>
|
42
50
|
<% end %>
|
43
51
|
</div>
|
52
|
+
|
53
|
+
<script>
|
54
|
+
Spree.current_order_id = "<%= @order.number %>"
|
55
|
+
Spree.current_order_token = "<%= @order.guest_token %>"
|
56
|
+
</script>
|
@@ -3,7 +3,7 @@
|
|
3
3
|
<table id="product-properties" class="table table-striped" data-hook>
|
4
4
|
<tbody>
|
5
5
|
<% @product_properties.each do |product_property| %>
|
6
|
-
<% css_class = cycle('even', 'odd', :
|
6
|
+
<% css_class = cycle('even', 'odd', name: "properties") %>
|
7
7
|
<tr class="<%= css_class %>">
|
8
8
|
<td><strong><%= product_property.property.presentation %></strong></td>
|
9
9
|
<td><%= product_property.value %></td>
|
@@ -1,10 +1,10 @@
|
|
1
|
-
<% if "spree/products" == params[:controller] && @taxon ||
|
1
|
+
<% if "spree/products" == params[:controller] && @taxon || @taxonomies.present? %>
|
2
2
|
<% content_for :sidebar do %>
|
3
3
|
<div data-hook="homepage_sidebar_navigation">
|
4
4
|
<% if "spree/products" == params[:controller] && @taxon %>
|
5
|
-
<%= render :
|
5
|
+
<%= render partial: 'spree/shared/filters' %>
|
6
6
|
<% else %>
|
7
|
-
<%= render :
|
7
|
+
<%= render partial: 'spree/shared/taxonomies' %>
|
8
8
|
<% end %>
|
9
9
|
</div>
|
10
10
|
<% end %>
|
@@ -15,13 +15,13 @@
|
|
15
15
|
<% if @products.empty? %>
|
16
16
|
<h6 class="search-results-title"><%= Spree.t(:no_products_found) %></h6>
|
17
17
|
<% else %>
|
18
|
-
<%= render :
|
18
|
+
<%= render partial: 'spree/shared/products', locals: { products: @products, taxon: @taxon } %>
|
19
19
|
<% end %>
|
20
20
|
</div>
|
21
21
|
<% else %>
|
22
22
|
<div data-hook="homepage_products">
|
23
23
|
<% cache(cache_key_for_products) do %>
|
24
|
-
<%= render :
|
24
|
+
<%= render partial: 'spree/shared/products', locals: { products: @products, taxon: @taxon } %>
|
25
25
|
<% end %>
|
26
26
|
</div>
|
27
27
|
<% end %>
|
@@ -7,20 +7,20 @@
|
|
7
7
|
<div id="product-images" data-hook="product_images">
|
8
8
|
<div id="main-image" class="panel panel-default" data-hook>
|
9
9
|
<div class="panel-body text-center">
|
10
|
-
<%=
|
10
|
+
<%= product_image(@product, itemprop: "image") %>
|
11
11
|
</div>
|
12
12
|
</div>
|
13
13
|
<div id="thumbnails" data-hook>
|
14
|
-
<%= render :
|
14
|
+
<%= render partial: 'thumbnails' %>
|
15
15
|
</div>
|
16
16
|
</div>
|
17
17
|
|
18
18
|
<div data-hook="product_properties">
|
19
|
-
<%= render :
|
19
|
+
<%= render partial: 'properties' %>
|
20
20
|
</div>
|
21
21
|
|
22
22
|
<div data-hook="promotions">
|
23
|
-
<%= render :
|
23
|
+
<%= render partial: 'promotions' %>
|
24
24
|
</div>
|
25
25
|
</div>
|
26
26
|
</div>
|
@@ -35,12 +35,12 @@
|
|
35
35
|
</div>
|
36
36
|
|
37
37
|
<div id="cart-form" data-hook="cart_form">
|
38
|
-
<%= render :
|
38
|
+
<%= render partial: 'cart_form' %>
|
39
39
|
</div>
|
40
40
|
</div>
|
41
41
|
|
42
42
|
<div id="taxon-crumbs" class=" five " data-hook="product_taxons">
|
43
|
-
<%= render :
|
43
|
+
<%= render partial: 'taxons' %>
|
44
44
|
</div>
|
45
45
|
</div>
|
46
46
|
</div>
|
@@ -18,7 +18,9 @@
|
|
18
18
|
</div>
|
19
19
|
<div class="local">
|
20
20
|
<span class="locality"><%= address.city %></span>
|
21
|
-
|
21
|
+
<% if Spree::Config[:address_requires_state] %>
|
22
|
+
<span class="region"><%= address.state_text %></span>
|
23
|
+
<% end %>
|
22
24
|
<span class="postal-code"><%= address.zipcode %></span>
|
23
25
|
<div class="country-name"><%= address.country.try(:name) %></div>
|
24
26
|
</div>
|
@@ -1,6 +1,6 @@
|
|
1
1
|
<% if target && target.errors.any? %>
|
2
2
|
<div id="errorExplanation" class="alert alert-danger" data-hook>
|
3
|
-
<h3><%= Spree.t(:errors_prohibited_this_record_from_being_saved, :
|
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
6
|
<% target.errors.full_messages.each do |msg| %>
|
@@ -1,7 +1,7 @@
|
|
1
1
|
<% filters = @taxon ? @taxon.applicable_filters : [Spree::Core::ProductFilters.all_taxons] %>
|
2
2
|
|
3
3
|
<% unless filters.empty? %>
|
4
|
-
<%= form_tag '', :
|
4
|
+
<%= form_tag '', method: :get, id: 'sidebar_products_search' do %>
|
5
5
|
<%= hidden_field_tag 'per_page', params[:per_page] %>
|
6
6
|
<% filters.each do |filter| %>
|
7
7
|
<% labels = filter[:labels] || filter[:conds].map {|m,c| [m,m]} %>
|
@@ -23,6 +23,6 @@
|
|
23
23
|
</ul>
|
24
24
|
</div>
|
25
25
|
<% end %>
|
26
|
-
<%= submit_tag Spree.t(:search), :
|
26
|
+
<%= submit_tag Spree.t(:search), name: nil, class: 'btn btn-primary' %>
|
27
27
|
<% end %>
|
28
28
|
<% end %>
|
@@ -1,10 +1,10 @@
|
|
1
1
|
<% order.line_items.each do |line_item| %>
|
2
2
|
ga('ec:addProduct', { // Provide product details in a productFieldObject.
|
3
|
-
'id': '<%= j (line_item.
|
4
|
-
'name': '<%= j line_item.
|
5
|
-
'category': '', // Product category (string).
|
6
|
-
'brand': '', // Product brand (string).
|
7
|
-
'variant': '', // Product variant (string).
|
3
|
+
'id': '<%= j (line_item.sku || line_item.variant_id) %>', // Product ID (string).
|
4
|
+
'name': '<%= j line_item.name %>', // Product name (string).
|
5
|
+
'category': '<%= j line_item.category.try(:name) %>', // Product category (string).
|
6
|
+
'brand': '<%= j line_item.brand.try(:name) %>', // Product brand (string).
|
7
|
+
'variant': '<%= j line_item.options_text %>', // Product variant (string).
|
8
8
|
'price': '<%= line_item.price %>',
|
9
9
|
'quantity': <%= line_item.quantity %>
|
10
10
|
});
|
@@ -7,8 +7,10 @@
|
|
7
7
|
<%= favicon_link_tag 'favicon.ico' %>
|
8
8
|
<%= stylesheet_link_tag 'spree/frontend/all', media: 'screen' %>
|
9
9
|
<%= csrf_meta_tags %>
|
10
|
+
<%= render 'spree/shared/paths' %>
|
10
11
|
<%= javascript_include_tag 'spree/frontend/all' %>
|
11
12
|
<!--[if lt IE 9]>
|
12
13
|
<script src="//cdnjs.cloudflare.com/ajax/libs/html5shiv/3.6/html5shiv.min.js"></script>
|
13
14
|
<![endif]-->
|
14
15
|
<%= yield :head %>
|
16
|
+
<%= render 'spree/shared/translations' %>
|
@@ -5,11 +5,11 @@
|
|
5
5
|
<figure id="logo" class="col-md-4 col-sm-3" data-hook>
|
6
6
|
<%= logo %>
|
7
7
|
</figure>
|
8
|
-
<%= render :
|
8
|
+
<%= render partial: 'spree/shared/nav_bar' %>
|
9
9
|
</div>
|
10
10
|
</div>
|
11
11
|
</header>
|
12
12
|
<div class="container">
|
13
|
-
<%= render :
|
13
|
+
<%= render partial: 'spree/shared/main_nav_bar' if store_menu? %>
|
14
14
|
</div>
|
15
15
|
</div>
|
@@ -1,10 +1,10 @@
|
|
1
|
-
<%= form_for Spree::User.new, :
|
1
|
+
<%= form_for Spree::User.new, as: :spree_user, url: spree.create_new_session_path do |f| %>
|
2
2
|
<fieldset id="password-credentials">
|
3
3
|
<div class="form-group">
|
4
|
-
<%= f.email_field :email, :
|
4
|
+
<%= f.email_field :email, class: 'form-control', tabindex: 1, placeholder: Spree.t(:email) %>
|
5
5
|
</div>
|
6
6
|
<div class="form-group">
|
7
|
-
<%= f.password_field :password, :
|
7
|
+
<%= f.password_field :password, class: 'form-control', tabindex: 2, placeholder: Spree.t(:password) %>
|
8
8
|
</div>
|
9
9
|
<div class="checkbox">
|
10
10
|
<label>
|
@@ -13,7 +13,7 @@
|
|
13
13
|
</label>
|
14
14
|
</div>
|
15
15
|
<div class="form-group">
|
16
|
-
<%= f.submit Spree.t(:login), :
|
16
|
+
<%= f.submit Spree.t(:login), class: 'btn btn-lg btn-success btn-block', tabindex: 3 %>
|
17
17
|
</div>
|
18
18
|
</fieldset>
|
19
19
|
<% end %>
|