Sha256: c256c51c0316ac368c68859f8e5fc72046b30cfd180d94486730b763c1b32166

Contents?: true

Size: 1.77 KB

Versions: 109

Compression:

Stored size: 1.77 KB

Contents

# frozen_string_literal: true

module Playbook
  module Spacing
    def self.included(base)
      base.prop :margin
      base.prop :margin_bottom
      base.prop :margin_left
      base.prop :margin_right
      base.prop :margin_top
      base.prop :margin_x
      base.prop :margin_y
      base.prop :max_width
      base.prop :padding
      base.prop :padding_bottom
      base.prop :padding_left
      base.prop :padding_right
      base.prop :padding_top
      base.prop :padding_x
      base.prop :padding_y
    end

    def spacing_options
      {
        margin: "m",
        margin_bottom: "mb",
        margin_left: "ml",
        margin_right: "mr",
        margin_top: "mt",
        margin_x: "mx",
        margin_y: "my",
        padding: "p",
        padding_bottom: "pb",
        padding_left: "pl",
        padding_right: "pr",
        padding_top: "pt",
        padding_x: "px",
        padding_y: "py",
      }
    end

    def spacing_values
      %w[none xxs xs sm md lg xl]
    end

    def spacing_props
      selected_props = spacing_options.keys.select { |sk| try(sk) }
      return nil unless selected_props.present?

      selected_props.map do |k|
        spacing_value = send(k)
        "#{spacing_options[k]}_#{spacing_value}" if spacing_values.include? spacing_value
      end.compact.join(" ")
    end

    def max_width_props
      selected_mw_props = max_width_options.keys.select { |sk| try(sk) }
      return nil unless selected_mw_props.present?

      selected_mw_props.map do |k|
        width_value = send(k)
        "max_width_#{width_value}" if max_width_values.include? width_value
      end.compact.join(" ")
    end

    def max_width_options
      {
        max_width: "mw",
      }
    end

    def max_width_values
      %w[xs sm md lg xl 0 none]
    end
  end
end

Version data entries

109 entries across 109 versions & 1 rubygems

Version Path
playbook_ui-12.7.1.pre.alpha.rubyandnpmalpharelease293 lib/playbook/spacing.rb
playbook_ui-12.7.1.pre.alpha.rubyandnpmalpharelease292 lib/playbook/spacing.rb
playbook_ui-12.7.1.pre.alpha.rubyandnpmalpharelease291 lib/playbook/spacing.rb
playbook_ui-12.7.1.pre.alpha.alpharubyrelease281 lib/playbook/spacing.rb
playbook_ui-12.7.1.pre.alpha.menu2 lib/playbook/spacing.rb
playbook_ui-12.7.1.pre.alpha.menu1 lib/playbook/spacing.rb
playbook_ui-12.7.1 lib/playbook/spacing.rb
playbook_ui-12.7.0 lib/playbook/spacing.rb
playbook_ui-12.6.0.pre.alpha.sectionseparator1 lib/playbook/spacing.rb
playbook_ui-12.6.0.pre.alpha.menuyml1 lib/playbook/spacing.rb
playbook_ui-12.6.0.pre.alpha.collapsible1 lib/playbook/spacing.rb
playbook_ui-12.6.0.pre.alpha.cssphone1 lib/playbook/spacing.rb
playbook_ui-12.6.0 lib/playbook/spacing.rb
playbook_ui-12.5.0.pre.alpha.datepickerinput1 lib/playbook/spacing.rb
playbook_ui-12.5.0.pre.alpha.phonerails1 lib/playbook/spacing.rb
playbook_ui-12.5.0.pre.alpha.datepicker1 lib/playbook/spacing.rb
playbook_ui-12.5.0.pre.alpha.filter1 lib/playbook/spacing.rb
playbook_ui-12.5.0 lib/playbook/spacing.rb
playbook_ui-12.4.0.pre.alpha.map1 lib/playbook/spacing.rb
playbook_ui-12.4.0.pre.alpha.devdocstest1 lib/playbook/spacing.rb