Module: Playbook::Flex
- Included in:
- KitBase
- Defined in:
- lib/playbook/flex.rb
Class Method Summary collapse
Instance Method Summary collapse
-
#flex_options ⇒ Object
rubocop:enable Style/IfInsideElse.
-
#flex_props ⇒ Object
rubocop:disable Style/IfInsideElse.
- #flex_values ⇒ Object
Class Method Details
.included(base) ⇒ Object
5 6 7 |
# File 'lib/playbook/flex.rb', line 5 def self.included(base) base.prop :flex end |
Instance Method Details
#flex_options ⇒ Object
rubocop:enable Style/IfInsideElse
37 38 39 40 41 |
# File 'lib/playbook/flex.rb', line 37 def { flex: "flex", } end |
#flex_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 |
# File 'lib/playbook/flex.rb', line 10 def flex_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| flex_value = send(k) if flex_value.is_a?(Hash) class_result = [] # Handle default value separately (generates base class without size prefix) class_result << "flex_#{flex_value[:default]}" if flex_value.key?(:default) && flex_values.include?(flex_value[:default].to_s) # Handle responsive sizes (generates classes with size prefix) flex_value.each do |media_size, value| class_result << "flex_#{media_size}_#{value}" if screen_size_values.include?(media_size.to_s) && flex_values.include?(value.to_s) end class_result else "flex_#{flex_value}" if flex_values.include? flex_value.to_s end end.flatten.compact.join(" ") end |
#flex_values ⇒ Object
43 44 45 |
# File 'lib/playbook/flex.rb', line 43 def flex_values %w[auto initial 0 1 2 3 4 5 6 7 8 9 10 11 12 none] end |