Sha256: 907140804125a68980ca4173823487a10c5ee63a318b6cda2b5e6e713efa7129
Contents?: true
Size: 1.82 KB
Versions: 9
Compression:
Stored size: 1.82 KB
Contents
# frozen_string_literal: true module UiBibz::Ui::Core::Forms::Dropdowns::Components # Create DropdownLink # # This element is an extend of UiBibz::Ui::Core::Component. # # ==== Attributes # # * +content+ - Content of element # * +options+ - Options of element # * +html_options+ - Html Options of element # # ==== Options # # You can add HTML attributes using the +html_options+. # You can pass arguments in options attribute: # * +state+ - status of element with symbol value: # (+:active+) # * +url+ - String # * +glyph+ - Add glyph with name or hash options # * +name+ - String # * +size+ - Integer # * +type+ - Symbol # * +link_html_options+ - Hash # # ==== Signatures # # UiBibz::Ui::Core::Forms::DropdownLink.new(content, options = nil, html_options = nil) # # UiBibz::Ui::Core::Forms::DropdownLink.new(options = nil, html_options = nil) do # content # end # # ==== Examples # # UiBibz::Ui::Core::Forms::DropdownLink.new('Home', { glyph: 'home', state: :active, url: '#home', link_html_options: { class: 'link1' }},{ class: 'test' }).render # # UiBibz::Ui::Core::Forms::DropdownLink.new({ glyph: { name: 'eye', size: 3 }, url: '#home' }, { class: 'test' }) do # 'Home' # end.render # class DropdownLink < UiBibz::Ui::Core::Component # See UiBibz::Ui::Core::Component.initialize def initialize(...) super @html_options = @html_options.merge(link_html_options) end # Render html tag def pre_render link_to glyph_and_content_html, link_url, html_options end private def component_html_classes 'dropdown-item' end def link_url options[:url] || '#' end def link_html_options @options[:link_html_options].nil? ? {} : @options[:link_html_options] end end end
Version data entries
9 entries across 9 versions & 1 rubygems