Handle list arguments to prefixes
This commit is contained in:
parent
6e30099473
commit
dd921ea363
lib/compass/sass_extensions/functions
test/fixtures/stylesheets/compass
@ -141,18 +141,26 @@ module Compass::SassExtensions::Functions::GradientSupport
|
|||||||
%w(webkit moz o ms svg pie).each do |prefix|
|
%w(webkit moz o ms svg pie).each do |prefix|
|
||||||
class_eval <<-RUBY, __FILE__, __LINE__ + 1
|
class_eval <<-RUBY, __FILE__, __LINE__ + 1
|
||||||
def _#{prefix}(*args)
|
def _#{prefix}(*args)
|
||||||
List.new(*args.map! do |a|
|
List.new(*args.map! {|a| add_prefix(:to_#{prefix}, a)}, :comma)
|
||||||
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)
|
|
||||||
end
|
end
|
||||||
RUBY
|
RUBY
|
||||||
end
|
end
|
||||||
|
|
||||||
protected
|
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)
|
def color_stop?(arg)
|
||||||
parse_color_stop(arg)
|
parse_color_stop(arg)
|
||||||
rescue
|
rescue
|
||||||
@ -219,7 +227,12 @@ module Compass::SassExtensions::Functions::GradientSupport
|
|||||||
|
|
||||||
# Returns a comma-delimited list after removing any non-true values
|
# Returns a comma-delimited list after removing any non-true values
|
||||||
def compact(*args)
|
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
|
end
|
||||||
|
|
||||||
# Returns a list object from a value that was passed.
|
# 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.
|
# Check if any of the arguments passed have a tendency towards vendor prefixing.
|
||||||
def prefixed(prefix, *args)
|
def prefixed(prefix, *args)
|
||||||
method = prefix.value.sub(/^-/,"to_").to_sym
|
method = prefix.value.sub(/^-/,"to_").to_sym
|
||||||
|
2.times do
|
||||||
args.map!{|a| a.is_a?(Sass::Script::List) ? a.value : a}.flatten!
|
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)})
|
Sass::Script::Bool.new(args.any?{|a| a.respond_to?(method)})
|
||||||
end
|
end
|
||||||
|
|
||||||
%w(webkit moz o ms svg pie).each do |prefix|
|
%w(webkit moz o ms svg pie).each do |prefix|
|
||||||
class_eval <<-RUBY, __FILE__, __LINE__ + 1
|
class_eval <<-RUBY, __FILE__, __LINE__ + 1
|
||||||
def _#{prefix}(*args)
|
def _#{prefix}(*args)
|
||||||
Sass::Script::List.new(args.map! do |a|
|
Sass::Script::List.new(args.map! {|a| add_prefix(:to_#{prefix}, a)}, :comma)
|
||||||
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)
|
|
||||||
end
|
end
|
||||||
RUBY
|
RUBY
|
||||||
end
|
end
|
||||||
|
|
||||||
protected
|
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)
|
def color_stop?(arg)
|
||||||
arg.is_a?(ColorStop) ||
|
arg.is_a?(ColorStop) ||
|
||||||
(arg.is_a?(Sass::Script::List) && ColorStop.new(*arg.value)) ||
|
(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 {
|
.bg-simple-image {
|
||||||
background-image: url("foo.png"); }
|
background-image: url("foo.png"); }
|
||||||
|
|
||||||
@ -46,7 +61,7 @@
|
|||||||
list-style-image: url('/images/4x6.png?busted=true'); }
|
list-style-image: url('/images/4x6.png?busted=true'); }
|
||||||
|
|
||||||
.shorthand-list-image-plain {
|
.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 {
|
.direct-list-image-with-gradient {
|
||||||
list-style-image: -moz-radial-gradient(#00ff00, #ff0000 10px);
|
list-style-image: -moz-radial-gradient(#00ff00, #ff0000 10px);
|
||||||
|
@ -1,6 +1,15 @@
|
|||||||
@import compass/css3/images, compass/css3/gradient
|
@import compass/css3/images, compass/css3/gradient
|
||||||
|
|
||||||
$experimental-support-for-svg: true
|
$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
|
.bg-simple-image
|
||||||
+background-image(url('foo.png'))
|
+background-image(url('foo.png'))
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user