Class: Daisy::DataInput::RatingComponent
- Inherits:
-
LocoMotion::BaseComponent
- Object
- ViewComponent::Base
- LocoMotion::BaseComponent
- Daisy::DataInput::RatingComponent
- Defined in:
- app/components/daisy/data_input/rating_component.rb
Overview
The Rating component renders a DaisyUI styled rating input using radio buttons. It can be used standalone or with a form builder, allowing users to select a rating from 1 to a configurable maximum value. Supports customization of size, colors, and initial value.
Defined Under Namespace
Classes: RatingItemComponent
Constant Summary
Constants inherited from LocoMotion::BaseComponent
LocoMotion::BaseComponent::EMPTY_PART_IGNORED_TAGS, LocoMotion::BaseComponent::SELF_CLOSING_TAGS
Instance Attribute Summary collapse
-
#disabled ⇒ Object
readonly
Returns the value of attribute disabled.
-
#id ⇒ Object
readonly
Returns the value of attribute id.
-
#inputs_css ⇒ Object
readonly
Returns the value of attribute inputs_css.
-
#inputs_html ⇒ Object
readonly
Returns the value of attribute inputs_html.
-
#max ⇒ Object
readonly
Returns the value of attribute max.
-
#name ⇒ Object
readonly
Returns the value of attribute name.
-
#required ⇒ Object
readonly
Returns the value of attribute required.
-
#value ⇒ Object
readonly
Returns the value of attribute value.
Attributes inherited from LocoMotion::BaseComponent
Instance Method Summary collapse
-
#before_render ⇒ Object
Calls the #setup_component and #setup_hidden_input methods before rendering the component.
-
#initialize(**kws) ⇒ RatingComponent
constructor
Instantiate a new Rating component.
-
#setup_component ⇒ Object
Sets up the component by configuring the tag name and CSS classes.
-
#setup_hidden_input ⇒ Object
Sets up a hidden input so that the rating can start empty.
-
#star_items ⇒ Object
Declares some default items to use if no custom items are provided.
Methods inherited from LocoMotion::BaseComponent
build, #component_ref, #config_option, #cssify, define_modifier, define_modifiers, define_part, define_parts, define_size, define_sizes, #empty_part_content, #inspect, #part, register_component_initializer, register_component_setup, #rendered_css, #rendered_data, #rendered_html, #rendered_stimulus_controllers, #rendered_tag_name, renders_many, renders_one, set_component_name, #set_loco_parent, #strip_spaces
Constructor Details
#initialize(**kws) ⇒ RatingComponent
Instantiate a new Rating component.
76 77 78 79 80 81 82 83 84 85 86 87 |
# File 'app/components/daisy/data_input/rating_component.rb', line 76 def initialize(**kws) super @name = config_option(:name) @value = config_option(:value) @max = config_option(:max, 5) @disabled = config_option(:disabled, false) @required = config_option(:required, false) @id = config_option(:id) @inputs_css = config_option(:inputs_css) @inputs_html = config_option(:inputs_html, {}) end |
Instance Attribute Details
#disabled ⇒ Object (readonly)
Returns the value of attribute disabled.
51 52 53 |
# File 'app/components/daisy/data_input/rating_component.rb', line 51 def disabled @disabled end |
#id ⇒ Object (readonly)
Returns the value of attribute id.
51 52 53 |
# File 'app/components/daisy/data_input/rating_component.rb', line 51 def id @id end |
#inputs_css ⇒ Object (readonly)
Returns the value of attribute inputs_css.
51 52 53 |
# File 'app/components/daisy/data_input/rating_component.rb', line 51 def inputs_css @inputs_css end |
#inputs_html ⇒ Object (readonly)
Returns the value of attribute inputs_html.
51 52 53 |
# File 'app/components/daisy/data_input/rating_component.rb', line 51 def inputs_html @inputs_html end |
#max ⇒ Object (readonly)
Returns the value of attribute max.
51 52 53 |
# File 'app/components/daisy/data_input/rating_component.rb', line 51 def max @max end |
#name ⇒ Object (readonly)
Returns the value of attribute name.
51 52 53 |
# File 'app/components/daisy/data_input/rating_component.rb', line 51 def name @name end |
#required ⇒ Object (readonly)
Returns the value of attribute required.
51 52 53 |
# File 'app/components/daisy/data_input/rating_component.rb', line 51 def required @required end |
#value ⇒ Object (readonly)
Returns the value of attribute value.
51 52 53 |
# File 'app/components/daisy/data_input/rating_component.rb', line 51 def value @value end |
Instance Method Details
#before_render ⇒ Object
Calls the #setup_component and #setup_hidden_input methods before rendering the component. This prepares the rating container and creates a hidden input if needed.
94 95 96 97 |
# File 'app/components/daisy/data_input/rating_component.rb', line 94 def before_render setup_component setup_hidden_input end |
#setup_component ⇒ Object
Sets up the component by configuring the tag name and CSS classes.
102 103 104 105 106 |
# File 'app/components/daisy/data_input/rating_component.rb', line 102 def setup_component set_tag_name(:component, :div) add_css(:component, "rating") add_html(:component, id: @id) if @id end |
#setup_hidden_input ⇒ Object
Sets up a hidden input so that the rating can start empty.
111 112 113 114 115 |
# File 'app/components/daisy/data_input/rating_component.rb', line 111 def setup_hidden_input set_tag_name(:hidden_input, :input) add_css(:hidden_input, "hidden") add_html(:hidden_input, { type: "radio", name: @name, value: nil, checked: @value.blank? }) end |
#star_items ⇒ Object
Declares some default items to use if no custom items are provided.
120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 |
# File 'app/components/daisy/data_input/rating_component.rb', line 120 def star_items (1..@max).map do || input_attrs = { loco_parent: component_ref, css: ["where:mask where:mask-star", @inputs_css].compact.join(" "), html: { name: @name, value: , checked: @value == , required: @required && == 1, disabled: @disabled, "aria-label": "#{rating} star", **@inputs_html } } RatingItemComponent.new(**input_attrs) end end |