Module: Playbook::AlignSelf
- Included in:
- KitBase
- Defined in:
- lib/playbook/align_self.rb
Class Method Summary collapse
Instance Method Summary collapse
- #align_self_options ⇒ Object
-
#align_self_props ⇒ Object
rubocop:disable Style/IfInsideElse.
- #align_self_values ⇒ Object
Class Method Details
.included(base) ⇒ Object
5 6 7 |
# File 'lib/playbook/align_self.rb', line 5 def self.included(base) base.prop :align_self end |
Instance Method Details
#align_self_options ⇒ Object
37 38 39 40 41 |
# File 'lib/playbook/align_self.rb', line 37 def { align_self: "align_self", } end |
#align_self_props ⇒ Object
rubocop:disable Style/IfInsideElse
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/playbook/align_self.rb', line 10 def align_self_props selected_props = .keys.select { |sk| try(sk) } return nil unless selected_props.present? screen_size_values = %w[xs sm md lg xl] selected_props.map do |k| align_self_value = send(k) if align_self_value.is_a?(Hash) class_result = [] # Handle default value separately (generates base class without size prefix) class_result << "align_self_#{align_self_value[:default]}" if align_self_value.key?(:default) && align_self_values.include?(align_self_value[:default]) # Handle responsive sizes (generates classes with size prefix) align_self_value.each do |media_size, align_value| class_result << "align_self_#{media_size}_#{align_value}" if screen_size_values.include?(media_size.to_s) && align_self_values.include?(align_value) end class_result else "align_self_#{align_self_value}" if align_self_values.include? align_self_value end end.flatten.compact.join(" ") # rubocop:enable Style/IfInsideElse end |
#align_self_values ⇒ Object
43 44 45 |
# File 'lib/playbook/align_self.rb', line 43 def align_self_values %w[auto start end center stretch baseline] end |