Sha256: 5a19d1060c7def39e44427d0890f6bfc1d38347f96e0d1925bf0048a1db8dc27

Contents?: true

Size: 1.94 KB

Versions: 11

Compression:

Stored size: 1.94 KB

Contents

module SCSSLint
  # Checks the declaration order of properties.
  class Linter::SortedProperties < Linter
    include LinterRegistry

    def visit_rule(node)
      # Ignore properties that contain interpolation
      sortable_props = node.children.select do |child|
        child.is_a?(Sass::Tree::PropNode) &&
          child.name.all? { |part| part.is_a?(String) }
      end

      sortable_prop_names = sortable_props.map { |child| child.name.join }

      sorted_prop_names = sortable_prop_names.map do |name|
        /^(?<vendor>-\w+-)?(?<property>.+)/ =~ name
        { name: name, vendor: vendor, property: property }
      end.sort { |a, b| compare_properties(a, b) }
         .map { |fields| fields[:name] }

      sorted_prop_names.each_with_index do |name, index|
        # Report the first property out of order with the sorted list
        if name != sortable_prop_names[index]
          add_lint(sortable_props[index])
          break
        end
      end

      yield # Continue linting children
    end

    def description
      'Properties should be sorted in alphabetical order, with ' <<
      'vendor-prefixed extensions before the standardized CSS property'
    end

  private

    # Compares two properties which can contain a vendor prefix. It allows for a
    # sort order like:
    #
    #   p {
    #     border: ...
    #     -moz-border-radius: ...
    #     -o-border-radius: ...
    #     -webkit-border-radius: ...
    #     border-radius: ...
    #     color: ...
    #   }
    #
    # ...where vendor-prefixed properties come before the standard property, and
    # are ordered amongst themselves by vendor prefix.
    def compare_properties(a, b)
      if a[:property] == b[:property]
        if a[:vendor] && b[:vendor]
          a[:vendor] <=> b[:vendor]
        elsif a[:vendor]
          -1
        elsif b[:vendor]
          1
        else
          0
        end
      else
        a[:property] <=> b[:property]
      end
    end
  end
end

Version data entries

11 entries across 11 versions & 1 rubygems

Version Path
scss-lint-0.17.3 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.17.2 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.17.1 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.17.0 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.16.1 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.16.0 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.15.0 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.14.0 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.13.0 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.12.1 lib/scss_lint/linter/sorted_properties.rb
scss-lint-0.12.0 lib/scss_lint/linter/sorted_properties.rb