Class: Daisy::Feedback::SkeletonComponent

Inherits:
LocoMotion::BaseComponent show all
Defined in:
app/components/daisy/feedback/skeleton_component.rb

Overview

The SkeletonComponent creates loading placeholder elements that mimic the shape and size of content that is being loaded. This provides users with a visual indication of the content’s layout before it arrives, reducing perceived loading times and improving user experience.

Skeletons can be used in two ways:

  1. As standalone shapes with custom dimensions.

  2. As a modifier class on existing components to create component-specific loading states.

Constant Summary

Constants inherited from LocoMotion::BaseComponent

LocoMotion::BaseComponent::EMPTY_PART_IGNORED_TAGS, LocoMotion::BaseComponent::SELF_CLOSING_TAGS

Instance Attribute Summary

Attributes inherited from LocoMotion::BaseComponent

#config, #loco_parent

Instance Method Summary collapse

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, #initialize, #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

This class inherits a constructor from LocoMotion::BaseComponent

Instance Method Details

#before_renderObject

Creates a new Skeleton component.



46
47
48
# File 'app/components/daisy/feedback/skeleton_component.rb', line 46

def before_render
  add_css(:component, "skeleton")
end

#callObject



50
51
52
# File 'app/components/daisy/feedback/skeleton_component.rb', line 50

def call
  part(:component) { content }
end