From 32a5ae26a8ce35aa555a4b60dbdc14d9000c0dcb Mon Sep 17 00:00:00 2001 From: Chris Eppstein Date: Sun, 28 Mar 2010 23:06:56 -0700 Subject: [PATCH] Better display of mixin signatures. --- doc-src/content/stylesheets/main.sass | 6 ++++++ doc-src/layouts/default.haml | 4 ++++ doc-src/lib/stylesheets.rb | 4 ++-- doc-src/lib/stylesheets/sass_extensions.rb | 24 ++++++++++++++-------- 4 files changed, 27 insertions(+), 11 deletions(-) diff --git a/doc-src/content/stylesheets/main.sass b/doc-src/content/stylesheets/main.sass index f8e50822..adbea73a 100644 --- a/doc-src/content/stylesheets/main.sass +++ b/doc-src/content/stylesheets/main.sass @@ -68,6 +68,12 @@ body.reference a.permalink +hover-link +link-colors("inherit", "inherit") + .arg[data-default-value] + color: #666 + &:before + content: "[" + &:after + content: "]" .source-documentation background-color: #eee border: 1px solid #aaa diff --git a/doc-src/layouts/default.haml b/doc-src/layouts/default.haml index a60a4999..6732ad74 100644 --- a/doc-src/layouts/default.haml +++ b/doc-src/layouts/default.haml @@ -25,5 +25,9 @@ e = $(e); e.after(''); }); + $('span.arg[data-default-value]').each(function(i,e){ + e = $(e); + e.attr("title", "Defaults to: " + e.attr("data-default-value")) + }) }); = render "partials/analytics" diff --git a/doc-src/lib/stylesheets.rb b/doc-src/lib/stylesheets.rb index 7455e0b0..884e47e5 100644 --- a/doc-src/lib/stylesheets.rb +++ b/doc-src/lib/stylesheets.rb @@ -135,8 +135,8 @@ def constants(item) constants end -def mixin_signature(mixin) - mixin.sass_signature(:include) +def mixin_signature(mixin, format = :html) + mixin.sass_signature(:include, format) end def example_items diff --git a/doc-src/lib/stylesheets/sass_extensions.rb b/doc-src/lib/stylesheets/sass_extensions.rb index db998da0..6881fd77 100644 --- a/doc-src/lib/stylesheets/sass_extensions.rb +++ b/doc-src/lib/stylesheets/sass_extensions.rb @@ -118,30 +118,36 @@ module Sass "#{sass_signature}\n #{children_to_sass}\n" end - def sass_signature(mode = :definition) + def sass_signature(mode = :definition, format = :text) prefix = case mode when :definition "=" when :include "+" end - "#{prefix}#{name}#{arglist_to_sass}" + "#{prefix}#{name}#{arglist_to_sass(format)}" end private - def arglist_to_sass + def arglist_to_sass(format = :text) if args && args.any? - "(#{args.map{|a| arg_to_sass(a)}.join(", ")})" + "(#{args.map{|a| arg_to_sass(a, format)}.join(", ")})" else "" end end - def arg_to_sass(arg) + def arg_to_sass(arg, format = :text) name, default_value = arg - sass_str = "#{name.inspect}" - if default_value - sass_str << " = " - sass_str << default_value.to_sass + sass_str = "" + if format == :html + ddv = %Q{ data-default-value="#{h(default_value.to_sass)}"} if default_value + sass_str = %Q{#{name.inspect}} + else + sass_str = "#{name.inspect}" + if default_value + sass_str << " = " + sass_str << default_value.to_sass + end end sass_str end