Class: Bootstrap4Helper::Nav
- Defined in:
- lib/bootstrap4_helper/nav.rb
Overview
Builds a Nav Component that can be used in other components.
Instance Method Summary collapse
-
#dropdown(name, opts = {}, &block) ⇒ String
Creates a dropdown menu for the nav.
-
#initialize(template, opts = {}, &block) ⇒ Nav
constructor
Class constructor.
-
#item(target, opts = {}) ⇒ String
Adds an nav-item to the nav component.
-
#link(name = nil, options = nil, html_options = nil, &block) ⇒ String
Use this when the nav item is nothing more than a hyperlink.
-
#to_s ⇒ String
String representation of the object.
Methods inherited from Component
#capture, #concat, #config, #content_tag, #parse_arguments, #uuid
Constructor Details
#initialize(template, opts = {}, &block) ⇒ Nav
Class constructor
15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/bootstrap4_helper/nav.rb', line 15 def initialize(template, opts = {}, &block) super(template) @id = opts.fetch(:id, uuid) @class = opts.fetch(:class, '') @data = opts.fetch(:data, {}) @child = opts.fetch(:child, {}) @content = block || proc { '' } @dropdown = Dropdown.new(@template) end |
Instance Method Details
#dropdown(name, opts = {}, &block) ⇒ String
Creates a dropdown menu for the nav.
84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 |
# File 'lib/bootstrap4_helper/nav.rb', line 84 def dropdown(name, opts = {}, &block) id = opts.fetch(:id, nil) klass = opts.fetch(:class, '') data = opts.fetch(:data, {}) aria = opts.fetch(:aria, {}).merge(haspopup: true, expanded: false) content_tag :li, id: id, class: 'nav-item dropdown', data: data do content_tag( :a, name, class: "nav-link dropdown-toggle #{klass}", href: '#', data: { toggle: 'dropdown' }, role: 'button', aria: aria ) + @dropdown.(opts, &block).to_s.html_safe end end |
#item(target, opts = {}) ⇒ String
Adds an nav-item to the nav component. this method gets used when the nav-item links to content in a tab or something.
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 |
# File 'lib/bootstrap4_helper/nav.rb', line 40 def item(target, opts = {}) id = opts.fetch(:id, nil) klass = opts.fetch(:class, '') data = opts.fetch(:data, {}) aria = opts.fetch(:aria, {}) content_tag :li, id: id, class: 'nav-item', data: data do content_tag( :a, class: "nav-link #{klass}", href: "##{target}", tabindex: -1, data: @child[:data], aria: aria ) do block_given? ? yield : target.to_s.titleize end end end |
#link(name = nil, options = nil, html_options = nil, &block) ⇒ String
Use this when the nav item is nothing more than a hyperlink.
68 69 70 71 72 |
# File 'lib/bootstrap4_helper/nav.rb', line 68 def link(name = nil, = nil, = nil, &block) = ( || {}).merge(class: 'nav-link') @template.link_to(name, , , &block) end |
#to_s ⇒ String
String representation of the object.
107 108 109 110 111 |
# File 'lib/bootstrap4_helper/nav.rb', line 107 def to_s content_tag :ul, id: @id, class: "nav #{@class}" do @content.call(self) end end |