2021-04-07 05:09:06 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Sidebars::Menu do
|
|
|
|
let(:menu) { described_class.new(context) }
|
|
|
|
let(:context) { Sidebars::Context.new(current_user: nil, container: nil) }
|
2021-05-10 14:10:41 -04:00
|
|
|
let(:nil_menu_item) { Sidebars::NilMenuItem.new(item_id: :foo) }
|
2021-04-07 05:09:06 -04:00
|
|
|
|
|
|
|
describe '#all_active_routes' do
|
|
|
|
it 'gathers all active routes of items and the current menu' do
|
2021-04-23 08:09:52 -04:00
|
|
|
menu.add_item(Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: { path: %w(bar test) }))
|
|
|
|
menu.add_item(Sidebars::MenuItem.new(title: 'foo2', link: 'foo2', active_routes: { controller: 'fooc' }))
|
|
|
|
menu.add_item(Sidebars::MenuItem.new(title: 'foo3', link: 'foo3', active_routes: { controller: 'barc' }))
|
2021-05-10 14:10:41 -04:00
|
|
|
menu.add_item(nil_menu_item)
|
2021-04-07 05:09:06 -04:00
|
|
|
|
|
|
|
allow(menu).to receive(:active_routes).and_return({ path: 'foo' })
|
|
|
|
|
2021-05-10 14:10:41 -04:00
|
|
|
expect(menu).to receive(:renderable_items).and_call_original
|
2021-04-07 05:09:06 -04:00
|
|
|
expect(menu.all_active_routes).to eq({ path: %w(foo bar test), controller: %w(fooc barc) })
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#render?' do
|
|
|
|
context 'when the menus has no items' do
|
2021-04-23 08:09:52 -04:00
|
|
|
it 'returns false' do
|
|
|
|
expect(menu.render?).to be false
|
2021-04-07 05:09:06 -04:00
|
|
|
end
|
2021-07-21 17:10:10 -04:00
|
|
|
|
|
|
|
context 'when menu has a partial' do
|
|
|
|
it 'returns true' do
|
|
|
|
allow(menu).to receive(:menu_partial).and_return('foo')
|
|
|
|
|
|
|
|
expect(menu.render?).to be true
|
|
|
|
end
|
|
|
|
end
|
2021-04-07 05:09:06 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the menu has items' do
|
2021-04-23 08:09:52 -04:00
|
|
|
it 'returns true' do
|
|
|
|
menu.add_item(Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: {}))
|
2021-04-07 05:09:06 -04:00
|
|
|
|
2021-04-23 08:09:52 -04:00
|
|
|
expect(menu.render?).to be true
|
2021-04-07 05:09:06 -04:00
|
|
|
end
|
2021-05-10 14:10:41 -04:00
|
|
|
|
|
|
|
context 'when menu items are NilMenuItem' do
|
|
|
|
it 'returns false' do
|
|
|
|
menu.add_item(nil_menu_item)
|
|
|
|
|
|
|
|
expect(menu.render?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#has_items?' do
|
|
|
|
it 'returns true when there are regular menu items' do
|
|
|
|
menu.add_item(Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: {}))
|
|
|
|
|
|
|
|
expect(menu.has_items?).to be true
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns true when there are nil menu items' do
|
|
|
|
menu.add_item(nil_menu_item)
|
|
|
|
|
|
|
|
expect(menu.has_items?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#has_renderable_items?' do
|
|
|
|
it 'returns true when there are regular menu items' do
|
|
|
|
menu.add_item(Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: {}))
|
|
|
|
|
|
|
|
expect(menu.has_renderable_items?).to be true
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns false when there are nil menu items' do
|
|
|
|
menu.add_item(nil_menu_item)
|
|
|
|
|
|
|
|
expect(menu.has_renderable_items?).to be false
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns true when there are both regular and nil menu items' do
|
|
|
|
menu.add_item(Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: {}))
|
|
|
|
menu.add_item(nil_menu_item)
|
|
|
|
|
|
|
|
expect(menu.has_renderable_items?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#renderable_items' do
|
|
|
|
it 'returns only regular menu items' do
|
|
|
|
item = Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: {})
|
|
|
|
menu.add_item(item)
|
|
|
|
menu.add_item(nil_menu_item)
|
|
|
|
|
|
|
|
expect(menu.renderable_items.size).to eq 1
|
|
|
|
expect(menu.renderable_items.first).to eq item
|
2021-04-23 08:09:52 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#insert_element_before' do
|
|
|
|
let(:item1) { Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: {}, item_id: :foo1) }
|
|
|
|
let(:item2) { Sidebars::MenuItem.new(title: 'foo2', link: 'foo2', active_routes: {}, item_id: :foo2) }
|
|
|
|
let(:item3) { Sidebars::MenuItem.new(title: 'foo3', link: 'foo3', active_routes: {}, item_id: :foo3) }
|
|
|
|
let(:list) { [item1, item2] }
|
|
|
|
|
|
|
|
it 'adds element before the specific element class' do
|
|
|
|
menu.insert_element_before(list, :foo2, item3)
|
|
|
|
|
|
|
|
expect(list).to eq [item1, item3, item2]
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not add nil elements' do
|
|
|
|
menu.insert_element_before(list, :foo2, nil)
|
|
|
|
|
|
|
|
expect(list).to eq [item1, item2]
|
|
|
|
end
|
2021-04-07 05:09:06 -04:00
|
|
|
|
2021-04-23 08:09:52 -04:00
|
|
|
context 'when reference element does not exist' do
|
|
|
|
it 'adds the element to the top of the list' do
|
|
|
|
menu.insert_element_before(list, :non_existent, item3)
|
2021-04-07 05:09:06 -04:00
|
|
|
|
2021-04-23 08:09:52 -04:00
|
|
|
expect(list).to eq [item3, item1, item2]
|
2021-04-07 05:09:06 -04:00
|
|
|
end
|
2021-04-23 08:09:52 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#insert_element_after' do
|
|
|
|
let(:item1) { Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: {}, item_id: :foo1) }
|
|
|
|
let(:item2) { Sidebars::MenuItem.new(title: 'foo2', link: 'foo2', active_routes: {}, item_id: :foo2) }
|
|
|
|
let(:item3) { Sidebars::MenuItem.new(title: 'foo3', link: 'foo3', active_routes: {}, item_id: :foo3) }
|
|
|
|
let(:list) { [item1, item2] }
|
|
|
|
|
|
|
|
it 'adds element after the specific element class' do
|
|
|
|
menu.insert_element_after(list, :foo1, item3)
|
|
|
|
|
|
|
|
expect(list).to eq [item1, item3, item2]
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not add nil elements' do
|
|
|
|
menu.insert_element_after(list, :foo1, nil)
|
|
|
|
|
|
|
|
expect(list).to eq [item1, item2]
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when reference element does not exist' do
|
|
|
|
it 'adds the element to the end of the list' do
|
|
|
|
menu.insert_element_after(list, :non_existent, item3)
|
2021-04-07 05:09:06 -04:00
|
|
|
|
2021-04-23 08:09:52 -04:00
|
|
|
expect(list).to eq [item1, item2, item3]
|
2021-04-07 05:09:06 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2021-05-31 11:11:12 -04:00
|
|
|
|
2021-11-19 07:12:41 -05:00
|
|
|
describe '#remove_element' do
|
|
|
|
let(:item1) { Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: {}, item_id: :foo1) }
|
|
|
|
let(:item2) { Sidebars::MenuItem.new(title: 'foo2', link: 'foo2', active_routes: {}, item_id: :foo2) }
|
|
|
|
let(:item3) { Sidebars::MenuItem.new(title: 'foo3', link: 'foo3', active_routes: {}, item_id: :foo3) }
|
|
|
|
let(:list) { [item1, item2, item3] }
|
|
|
|
|
|
|
|
it 'removes specific element' do
|
|
|
|
menu.remove_element(list, :foo2)
|
|
|
|
|
|
|
|
expect(list).to eq [item1, item3]
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not remove nil elements' do
|
|
|
|
menu.remove_element(list, nil)
|
|
|
|
|
|
|
|
expect(list).to eq [item1, item2, item3]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-05-31 11:11:12 -04:00
|
|
|
describe '#container_html_options' do
|
|
|
|
before do
|
|
|
|
allow(menu).to receive(:title).and_return('Foo Menu')
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when menu can be rendered' do
|
|
|
|
before do
|
|
|
|
allow(menu).to receive(:render?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when menu has renderable items' do
|
|
|
|
before do
|
|
|
|
menu.add_item(Sidebars::MenuItem.new(title: 'foo1', link: 'foo1', active_routes: { path: 'bar' }))
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'contains the special class' do
|
|
|
|
expect(menu.container_html_options[:class]).to eq 'has-sub-items'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when menu already has other classes' do
|
|
|
|
it 'appends special class' do
|
|
|
|
allow(menu).to receive(:extra_container_html_options).and_return(class: 'foo')
|
|
|
|
|
|
|
|
expect(menu.container_html_options[:class]).to eq 'foo has-sub-items'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when menu does not have renderable items' do
|
|
|
|
it 'does not contain the special class' do
|
|
|
|
expect(menu.container_html_options[:class]).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when menu cannot be rendered' do
|
|
|
|
before do
|
|
|
|
allow(menu).to receive(:render?).and_return(false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not contain special class' do
|
|
|
|
expect(menu.container_html_options[:class]).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2021-08-23 05:10:23 -04:00
|
|
|
|
|
|
|
describe '#link' do
|
|
|
|
let(:foo_path) { '/foo_path'}
|
|
|
|
|
|
|
|
let(:foo_menu) do
|
|
|
|
::Sidebars::MenuItem.new(
|
|
|
|
title: 'foo',
|
|
|
|
link: foo_path,
|
|
|
|
active_routes: {},
|
|
|
|
item_id: :foo
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns first visible menu item link' do
|
|
|
|
menu.add_item(foo_menu)
|
|
|
|
|
|
|
|
expect(menu.link).to eq foo_path
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns nil if there are no visible menu items' do
|
|
|
|
expect(menu.link).to be_nil
|
|
|
|
end
|
|
|
|
end
|
2021-04-07 05:09:06 -04:00
|
|
|
end
|