Handle list arguments to prefixes
This commit is contained in:
parent
6e30099473
commit
dd921ea363
@ -141,18 +141,26 @@ module Compass::SassExtensions::Functions::GradientSupport
|
||||
%w(webkit moz o ms svg pie).each do |prefix|
|
||||
class_eval <<-RUBY, __FILE__, __LINE__ + 1
|
||||
def _#{prefix}(*args)
|
||||
List.new(*args.map! do |a|
|
||||
if a.is_a?(List)
|
||||
a.class.new(*a.values.map{|v| v.respond_to?(:to_#{prefix}) ? v.to_#{prefix} : v})
|
||||
else
|
||||
a.respond_to?(:to_#{prefix}) ? a.to_#{prefix} : a
|
||||
end
|
||||
end)
|
||||
List.new(*args.map! {|a| add_prefix(:to_#{prefix}, a)}, :comma)
|
||||
end
|
||||
RUBY
|
||||
end
|
||||
|
||||
protected
|
||||
|
||||
def add_prefix(prefix_method, object)
|
||||
if object.is_a?(List)
|
||||
object.class.new(object.value.map{|e|
|
||||
add_prefix(prefix_method, e)
|
||||
})
|
||||
elsif object.respond_to?(prefix_method)
|
||||
object.options = options
|
||||
object.send(prefix_method)
|
||||
else
|
||||
object
|
||||
end
|
||||
end
|
||||
|
||||
def color_stop?(arg)
|
||||
parse_color_stop(arg)
|
||||
rescue
|
||||
@ -219,7 +227,12 @@ module Compass::SassExtensions::Functions::GradientSupport
|
||||
|
||||
# Returns a comma-delimited list after removing any non-true values
|
||||
def compact(*args)
|
||||
Sass::Script::List.new(args.reject{|a| !a.to_bool}, :comma)
|
||||
sep = :comma
|
||||
if args.size == 1 && args.first.is_a?(Sass::Script::List)
|
||||
args = args.first.value
|
||||
sep = args.first.separator
|
||||
end
|
||||
Sass::Script::List.new(args.reject{|a| !a.to_bool}, sep)
|
||||
end
|
||||
|
||||
# Returns a list object from a value that was passed.
|
||||
@ -259,28 +272,35 @@ module Compass::SassExtensions::Functions::GradientSupport
|
||||
# Check if any of the arguments passed have a tendency towards vendor prefixing.
|
||||
def prefixed(prefix, *args)
|
||||
method = prefix.value.sub(/^-/,"to_").to_sym
|
||||
2.times do
|
||||
args.map!{|a| a.is_a?(Sass::Script::List) ? a.value : a}.flatten!
|
||||
end
|
||||
Sass::Script::Bool.new(args.any?{|a| a.respond_to?(method)})
|
||||
end
|
||||
|
||||
%w(webkit moz o ms svg pie).each do |prefix|
|
||||
class_eval <<-RUBY, __FILE__, __LINE__ + 1
|
||||
def _#{prefix}(*args)
|
||||
Sass::Script::List.new(args.map! do |a|
|
||||
a.options = options
|
||||
if a.is_a?(Sass::Script::List)
|
||||
Sass::Script::List.new(a.value.map do |v|
|
||||
v.respond_to?(:to_#{prefix}) ? v.to_#{prefix} : v
|
||||
end, a.separator)
|
||||
else
|
||||
a.respond_to?(:to_#{prefix}) ? a.to_#{prefix} : a
|
||||
end
|
||||
end, :comma)
|
||||
Sass::Script::List.new(args.map! {|a| add_prefix(:to_#{prefix}, a)}, :comma)
|
||||
end
|
||||
RUBY
|
||||
end
|
||||
|
||||
protected
|
||||
|
||||
def add_prefix(prefix_method, object)
|
||||
if object.is_a?(Sass::Script::List)
|
||||
Sass::Script::List.new(object.value.map{|e|
|
||||
add_prefix(prefix_method, e)
|
||||
}, object.separator)
|
||||
elsif object.respond_to?(prefix_method)
|
||||
object.options = options
|
||||
object.send(prefix_method)
|
||||
else
|
||||
object
|
||||
end
|
||||
end
|
||||
|
||||
def color_stop?(arg)
|
||||
arg.is_a?(ColorStop) ||
|
||||
(arg.is_a?(Sass::Script::List) && ColorStop.new(*arg.value)) ||
|
||||
|
@ -1,3 +1,18 @@
|
||||
.bg-shortcut-simple-image {
|
||||
background: white url("foo.png"); }
|
||||
|
||||
.bg-shortcut-linear-gradient {
|
||||
background: white url('');
|
||||
background: white -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa));
|
||||
background: white -moz-linear-gradient(top left, #dddddd, #aaaaaa);
|
||||
background: white linear-gradient(top left, #dddddd, #aaaaaa); }
|
||||
|
||||
.bg-shortcut-radial-gradient {
|
||||
background: white url('');
|
||||
background: white -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 100, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa));
|
||||
background: white -moz-radial-gradient(center center, #dddddd, #aaaaaa 100px);
|
||||
background: white radial-gradient(center center, #dddddd, #aaaaaa 100px); }
|
||||
|
||||
.bg-simple-image {
|
||||
background-image: url("foo.png"); }
|
||||
|
||||
@ -46,7 +61,7 @@
|
||||
list-style-image: url('/images/4x6.png?busted=true'); }
|
||||
|
||||
.shorthand-list-image-plain {
|
||||
list-style-image: outside url("/images/4x6.png?busted=true"); }
|
||||
list-style-image: outside url('/images/4x6.png?busted=true'); }
|
||||
|
||||
.direct-list-image-with-gradient {
|
||||
list-style-image: -moz-radial-gradient(#00ff00, #ff0000 10px);
|
||||
|
@ -1,6 +1,15 @@
|
||||
@import compass/css3/images, compass/css3/gradient
|
||||
|
||||
$experimental-support-for-svg: true
|
||||
.bg-shortcut-simple-image
|
||||
+background(#fff url('foo.png'))
|
||||
|
||||
.bg-shortcut-linear-gradient
|
||||
+background(#fff linear-gradient(top left, #ddd, #aaa))
|
||||
|
||||
.bg-shortcut-radial-gradient
|
||||
+background(#fff radial-gradient(center center, #ddd, #aaa 100px))
|
||||
|
||||
.bg-simple-image
|
||||
+background-image(url('foo.png'))
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user