Skip to content
This repository has been archived by the owner on Jan 24, 2024. It is now read-only.

Commit

Permalink
minor improvements
Browse files Browse the repository at this point in the history
  • Loading branch information
oshiho3 committed Mar 17, 2015
1 parent 0c6b6e0 commit c253c86
Show file tree
Hide file tree
Showing 5 changed files with 97 additions and 65 deletions.
4 changes: 2 additions & 2 deletions app/assets/javascripts/crops.js.erb
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,6 @@ function showCropMap(cropmap) {
cropmap.addLayer(markers);
}

$('.btn.toggle').click(function () {
$('.toggle').toggleClass('hide');
$('.btn.toggle.crop-hierarchy').click(function () {
$('.toggle.crop-hierarchy').toggleClass('hide');
});
2 changes: 0 additions & 2 deletions app/assets/stylesheets/overrides.css.less
Original file line number Diff line number Diff line change
Expand Up @@ -320,5 +320,3 @@ html, body {
.hide {
display: none;
}


10 changes: 6 additions & 4 deletions app/views/crops/_hierarchy.html.haml
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
%ul
- @count ||= 5
- @count ||= 0
- unless defined? max
- max = 0 # list all without "show all" toggle button
- display_crops.each do |c|
%li.crop-hierarchy{:class => @count <= 0 ? ['hide', 'toggle'] : []}
%li.crop-hierarchy{:class => max != 0 && @count >= max ? ['hide', 'toggle'] : []}
= link_to c, c
- @count -= 1
- @count += 1
- if c.varieties.present?
- c.varieties.each do |v|
= render :partial => 'hierarchy', :locals => { :display_crops => [ v ] }
= render :partial => 'hierarchy', :locals => { :display_crops => [ v ], :max => max }
32 changes: 17 additions & 15 deletions app/views/crops/_varieties.html.haml
Original file line number Diff line number Diff line change
@@ -1,18 +1,20 @@
- if crop.parent
%p
= crop.name
is a variety of
= succeed "." do
= link_to crop.parent, crop.parent
.varieties
- if crop.parent
%p
= crop.name
is a variety of
= succeed "." do
= link_to crop.parent, crop.parent

- unless crop.varieties.empty?
%p
Varieties of #{crop.name}:
- unless crop.varieties.empty?
%p
Varieties of #{crop.name}:

= render :partial => 'hierarchy', :locals => { :display_crops => [ crop ] }
- if @count < 0
= button_tag "Show all #{crop.varieties.size} varieties", :class => 'btn btn-link toggle'
= button_tag "Show less varieties", :class => 'btn btn-link toggle hide'
- max = 5
= render :partial => 'hierarchy', :locals => { :display_crops => [ crop ], :max => max }
- if max != 0 && @count > max
= button_tag "Show all #{@count-1} varieties", :class => 'btn btn-link toggle crop-hierarchy'
= button_tag "Show less varieties", :class => 'btn btn-link toggle crop-hierarchy hide'

- if ! crop.parent and crop.varieties.empty?
%p None known.
- if ! crop.parent and crop.varieties.empty?
%p None known.
114 changes: 72 additions & 42 deletions spec/features/crops/crop_detail_page_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -5,58 +5,88 @@
let(:crop) { FactoryGirl.create(:crop) }

context "varieties" do
let!(:roma1) { FactoryGirl.create(:crop, :name => 'Roma tomato 1', :parent => crop) }
let!(:roma2) { FactoryGirl.create(:crop, :name => 'Roma tomato 2', :parent => crop) }
let!(:roma3) { FactoryGirl.create(:crop, :name => 'Roma tomato 3', :parent => crop) }
let!(:roma4) { FactoryGirl.create(:crop, :name => 'Roma tomato 4', :parent => crop) }

scenario "The crop has 4 varieties" do

scenario "The crop DOES NOT have varieties" do
visit crop_path(crop)

# It lists all 5 items (note: including the top level item.)
# It DOES NOT have "Show all/less" toggle link
expect(page).to have_css('li', text: /tomato/i, count: 5)
expect(page).to have_no_css('button', text: /Show all+/i)
expect(page).to have_no_css('button', text: /Show less+/i)
within ".varieties" do
expect(page).to have_no_selector('li', text: /tomato/i)
expect(page).to have_no_selector('button', text: /Show+/i)
end
end

scenario "The crop has more than 4 varieties", :js => true do
roma5 = FactoryGirl.create(:crop, :name => 'Roma tomato 5', :parent => crop)
scenario "The crop has one variety" do
roma1 = FactoryGirl.create(:crop, :name => 'Roma tomato 1', :parent => crop)

visit crop_path(crop)

# It lists the first 5 items (note: including the top level item.)
# It HAS have "Show all" toggle link but not "Show less" link
expect(page).to have_css('li', text: /tomato/i, count: 5)
expect(page).to have_css('li', text: 'Roma tomato 4')
expect(page).to have_no_css('li', text: 'Roma tomato 5')
expect(page).to have_css('button', text: /Show all+/i)
expect(page).to have_no_css('button', text: /Show less+/i)

# Clik "Show all" link
page.find('button', :text => /Show all+/).click

# It lists all 6 items (note: including the top level item.)
# It HAS have "Show all" toggle link but not "Show less" link
expect(page).to have_css('li', text: /tomato/i, count: 6)
expect(page).to have_css('li', text: 'Roma tomato 4')
expect(page).to have_css('li', text: 'Roma tomato 5')
expect(page).to have_no_selector('button', text: /Show all+/i)
expect(page).to have_selector('button', text: /Show less+/i)

# Clik "Show less" link
page.find('button', :text => /Show less+/).click

# It lists 5 items (note: including the top level item.)
# It HAS have "Show all" toggle link but not "Show less" link
expect(page).to have_css('li', text: /tomato/i, count: 5)
expect(page).to have_css('li', text: 'Roma tomato 4')
expect(page).to have_no_css('li', text: 'Roma tomato 5')
expect(page).to have_selector('button', text: /Show all+/i)
expect(page).to have_no_selector('button', text: /Show less+/i)
within ".varieties" do
# It lists all 2 items (note: including the top level item.)
expect(page).to have_selector('li', text: /tomato/i, count: 2)
# It DOES NOT have "Show all/less" toggle link
expect(page).to have_no_selector('button', text: /Show+/i)
end
end

context "many" do

let!(:roma1) { FactoryGirl.create(:crop, :name => 'Roma tomato 1', :parent => crop) }
let!(:roma2) { FactoryGirl.create(:crop, :name => 'Roma tomato 2', :parent => crop) }
let!(:roma3) { FactoryGirl.create(:crop, :name => 'Roma tomato 3', :parent => crop) }
let!(:roma4) { FactoryGirl.create(:crop, :name => 'Roma tomato 4', :parent => crop) }

scenario "The crop has 4 varieties" do

visit crop_path(crop)

within ".varieties" do
# It lists all 5 items (note: including the top level item.)
expect(page).to have_selector('li', text: /tomato/i, count: 5)
# It DOES NOT have "Show all/less" toggle link
expect(page).to have_no_selector('button', text: /Show+/i)
end
end

scenario "The crop has 5 varieties, including grandchild", :js => true do
roma_child1 = FactoryGirl.create(:crop, :name => 'Roma tomato child 1', :parent => roma4)

visit crop_path(crop)

within ".varieties" do

# It lists the first 5 items (note: including the top level item.)
# It HAS have "Show all" toggle link but not "Show less" link
expect(page).to have_selector('li', text: /tomato/i, count: 5)
expect(page).to have_selector('li', text: 'Roma tomato 4')
expect(page).to have_no_selector('li', text: 'Roma tomato child 1')
# It shows the total number (5) correctly
expect(page).to have_selector('button', text: /Show all 5 +/i)
expect(page).to have_no_selector('button', text: /Show less+/i)

# Clik "Show all" link
page.find('button', :text => /Show all+/).click

# It lists all 6 items (note: including the top level item.)
# It HAS have "Show less" toggle link but not "Show all" link
expect(page).to have_selector('li', text: /tomato/i, count: 6)
expect(page).to have_selector('li', text: 'Roma tomato 4')
expect(page).to have_selector('li', text: 'Roma tomato child 1')
expect(page).to have_no_selector('button', text: /Show all+/i)
expect(page).to have_selector('button', text: /Show less+/i)

# Clik "Show less" link
page.find('button', :text => /Show less+/).click

# It lists 5 items (note: including the top level item.)
# It HAS have "Show all" toggle link but not "Show less" link
expect(page).to have_selector('li', text: /tomato/i, count: 5)
expect(page).to have_selector('li', text: 'Roma tomato 4')
expect(page).to have_no_selector('li', text: 'Roma tomato child 1')
expect(page).to have_selector('button', text: /Show all 5 +/i)
expect(page).to have_no_selector('button', text: /Show less+/i)
end
end
end
end

context "signed in member" do
Expand Down

0 comments on commit c253c86

Please sign in to comment.