11.4 Iteration F4: Hide an Empty Cart 11.2 Iteration F2: Creating an AJAX-Based Cart
Assign the current item to be the line item in question
edit app/controllers/line_items_controller.rb
def create
product = Product.find(params[:product_id])
@line_item = @cart.add_product(product.id)
respond_to do |format|
if @line_item.save
format.html { redirect_to store_url }
format.js { @current_item = @line_item }
format.json { render :show,
status: :created, location: @line_item }
else
format.html { render :new }
format.json { render json: @line_item.errors,
status: :unprocessable_entity }
end
end
end
Add the id to the row in question
edit app/views/line_items/_line_item.html.erb
<% if line_item == @current_item %>
<tr id="current_item">
<% else %>
<tr>
<% end %>
<td><%= line_item.quantity %>×</td>
<td><%= line_item.product.title %></td>
<td class="item_price"><%= number_to_currency(line_item.total_price) %></td>
</tr>
Animate the background color of that row
edit app/views/line_items/create.js.erb
$('#cart').html("<%= escape_javascript render(@cart) %>");
$('#current_item').css({'background-color':'#88ff88'}).
animate({'background-color':'#114411'}, 1000);
Make the jquery-ui libraries available to the application
edit Gemfile
# Use jQuery as the JavaScript library
gem 'jquery-rails', '~> 4.0.0.beta2'
gem 'jquery-ui-rails'
Install the gem
bundle install --local
Resolving dependencies...
Using rake 10.3.2
Using i18n 0.7.0.beta1
Using json 1.8.1
Using minitest 5.4.1
Using thread_safe 0.3.4
Using tzinfo 1.2.2
Using activesupport 4.2.0.beta1 from source at /home/rubys/git/rails
Using builder 3.2.2
Using erubis 2.7.0
Using mini_portile 0.6.0
Using nokogiri 1.6.3.1
Using rails-deprecated_sanitizer 1.0.2 from source at /home/rubys/git/rails-deprecated_sanitizer
Using rails-dom-testing 1.0.2 from source at /home/rubys/git/rails-dom-testing
Using loofah 2.0.1
Using rails-html-sanitizer 1.0.0 from source at /home/rubys/git/rails-html-sanitizer
Using actionview 4.2.0.beta1 from source at /home/rubys/git/rails
Using rack 1.6.0.beta
Using rack-test 0.6.2
Using actionpack 4.2.0.beta1 from source at /home/rubys/git/rails
Using globalid 0.3.0
Using activejob 4.2.0.beta1 from source at /home/rubys/git/rails
Using mime-types 2.3
Using mail 2.6.1
Using actionmailer 4.2.0.beta1 from source at /home/rubys/git/rails
Using activemodel 4.2.0.beta1 from source at /home/rubys/git/rails
Using arel 6.0.0.beta1
Using activerecord 4.2.0.beta1 from source at /home/rubys/git/rails
Using debug_inspector 0.0.2
Using binding_of_caller 0.7.3.pre1
Using bundler 1.7.3
Using columnize 0.8.9
Using debugger-linecache 1.2.0
Using slop 3.6.0
Using byebug 3.4.0
Using coffee-script-source 1.8.0
Using execjs 2.2.1
Using coffee-script 2.3.0
Using thor 0.19.1
Using railties 4.2.0.beta1 from source at /home/rubys/git/rails
Using coffee-rails 4.0.1 from source at /home/rubys/git/coffee-rails
Using hike 1.2.3
Using multi_json 1.10.1
Using jbuilder 2.1.3
Using jquery-rails 4.0.0.beta2
Using jquery-ui-rails 5.0.0
Using qu 0.2.0 from source at /home/rubys/git/qu-rails
Using qu-rails 0.2.0 from source at /home/rubys/git/qu-rails
Using tilt 1.4.1
Using sprockets 2.12.2
Using sprockets-rails 3.0.0.beta1 from source at /home/rubys/git/sprockets-rails
Using rails 4.2.0.beta1 from source at /home/rubys/git/rails
Using rdoc 4.1.2
Using sass 3.4.5
Using sass-rails 5.0.0.beta1 from source at /home/rubys/git/sass-rails
Using sdoc 0.4.1
Using spring 1.1.3
Using sqlite3 1.3.9
Using turbolinks 2.3.0
Using uglifier 2.5.3
Using web-console 2.0.0.beta3 from source at /home/rubys/git/web-console
Your bundle is complete!
Use `bundle show [gemname]` to see where a bundled gem is installed.
Pull in the blind effect from the jquery-ui libraries
edit app/assets/javascripts/application.js
// This is a manifest file that'll be compiled into application.js, which will
// include all the files listed below.
//
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts,
// vendor/assets/javascripts, or vendor/assets/javascripts of plugins, if any,
// can be referenced here using a relative path.
//
// It's not advisable to add code directly here, but if you do, it'll appear at
// the bottom of the compiled file.
//
// Read Sprockets README
// (https://github.com/sstephenson/sprockets#sprockets-directives) for details
// about supported directives.
//
//= require jquery
//= require jquery-ui/effect-blind
//= require jquery_ujs
//= require turbolinks
//= require_tree .
11.4 Iteration F4: Hide an Empty Cart 11.2 Iteration F2: Creating an AJAX-Based Cart