summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authormakoto kuwata <kwa@kuwata-lab.com>2008-01-29 08:40:39 +0000
committermakoto kuwata <kwa@kuwata-lab.com>2008-01-29 08:40:39 +0000
commit62ebde5610bb41ff0335ffd3d11699a532726975 (patch)
treeac81969eb540466fd0cb12bd3b065fe3dc52aee7 /lib
parent4ca35ae82dc946df548e5b399625a2ffb72946e9 (diff)
downloaderubis-62ebde5610bb41ff0335ffd3d11699a532726975.tar.gz
- [enhance] add 'helpers/rails_form_helper.rb'
- [change] helpers/rails_helper.rb: rename _expr() to _p() - [enhance] helpers/rails_helper.rb: add _P() - [enhance] helpers/rails_helper.rb: support Rails 2.0 - [update] users-guide.txt - [change] rename 'CHANGES' to 'CHANGES.txt'
Diffstat (limited to 'lib')
-rw-r--r--lib/erubis/helpers/rails_form_helper.rb190
-rw-r--r--lib/erubis/helpers/rails_helper.rb83
2 files changed, 249 insertions, 24 deletions
diff --git a/lib/erubis/helpers/rails_form_helper.rb b/lib/erubis/helpers/rails_form_helper.rb
new file mode 100644
index 0000000..bc1520e
--- /dev/null
+++ b/lib/erubis/helpers/rails_form_helper.rb
@@ -0,0 +1,190 @@
+###
+### $Rev$
+### $Release: $
+### $Copyright$
+###
+
+
+module Erubis
+ module Helpers
+ module RailsFormHelper
+ end
+ end
+end
+
+
+module Erubis::Helpers::RailsFormHelper
+
+ def pp_template_filename(basename)
+ return "#{RAILS_ROOT}/app/views/#{controller.controller_name}/#{basename}.rhtml"
+ end
+
+ def pp_render_partial(basename)
+ basename = "_#{basename}" unless basename[0] == ?_
+ filename = pp_template_filename(basename)
+ klass = Erubis::Helpers::RailsHelper::PreprocessingEruby
+ eruby = klass.new(File.read(filename))
+ return eruby.evaluate(self)
+ end
+
+ def pp_error_on(object_name, method, &block)
+ s = ''
+ s << "<% _stag, _etag = _pp_error_tags(@#{object_name}.errors.on('#{method}'))%>"
+ s << "<%=_stag%>"
+ s << yield(object_name, method)
+ s << "<%=_etag%>"
+ return s
+ end
+
+ def _pp_error_tags(value)
+ return value ? ['<div class="fieldWithErrors">', '</div>'] : ['', '']
+ end
+
+ def _pp_remove_error_div(s)
+ s.sub!(/\A<div class="fieldWithErrors">(.*)<\/div>\z/, '\1')
+ return s
+ end
+
+ def pp_tag_helper(helper, object_name, method, options={})
+ if object_name.is_a?(ActionView::Helpers::FormHelper)
+ object_name = object_name.object_name
+ end
+ unless options.key?(:value) || options.key?('value')
+ options['value'] = _?("h @#{object_name}.#{method}")
+ end
+ $stderr.puts "*** debug: pp_tag_helper(): options=#{options.inspect}"
+ return pp_error_on(object_name, method) {
+ s = __send__(helper, object_name, method, options)
+ _pp_remove_error_div(s)
+ }
+ end
+
+ def pp_form_tag(url_for_options={}, options={}, *parameters_for_url, &block)
+ return form_tag(url_for_options, options, *parameters_for_url, &block)
+ end
+
+ #--
+ #def pp_form_for(object_name, *args, &block)
+ # return form_for(object_name, *args, &block)
+ #end
+ #++
+
+ def pp_text_field(object_name, method, options={})
+ return pp_tag_helper(:text_field, object_name, method, options)
+ end
+
+ def pp_password_field(object_name, method, options={})
+ return pp_tag_helper(:password_field, object_name, method, options)
+ end
+
+ def pp_hidden_field(object_name, method, options={})
+ return pp_tag_helper(:hidden_field, object_name, method, options)
+ end
+
+ def pp_file_field(object_name, method, options={})
+ return pp_tag_helper(:file_field, object_name, method, options)
+ end
+
+ def pp_text_area(object_name, method, options={})
+ return pp_tag_helper(:text_area, object_name, method, options)
+ end
+
+ def pp_check_box(object_name, method, options={}, checked_value="1", unchecked_value="0")
+ s = check_box(object_name, method, options, checked_value, unchecked_value)
+ s.sub!(/\schecked=\"checked\"/, '')
+ s.sub!(/type="checkbox"/, "\\&<%= _pp_check_box_checked?(@#{object_name}.#{method}, #{checked_value.inspect}) ? ' checked=\"checked\"' : '' %>")
+ return pp_error_on(object_name, method) { _pp_remove_error_div(s) }
+ end
+
+ def _pp_check_box_checked?(value, checked_value)
+ return ActionView::Helpers::InstanceTag::check_box_checked?(value, checked_value)
+ end
+
+ def pp_radio_button(object_name, method, tag_value, options={})
+ s = radio_button(object_name, method, tag_value, options)
+ s.sub!(/\schecked=\"checked\"/, '')
+ s.sub!(/type="radio"/, "\\&<%= _pp_radio_button_checked?(@#{object_name}.#{method}, #{tag_value.inspect}) ? ' checked=\"checked\"' : '' %>")
+ return pp_error_on(object_name, method) { _pp_remove_error_div(s) }
+ end
+
+ def _pp_radio_button_checked?(value, tag_value)
+ return ActionView::Helpers::InstanceTag::radio_button_checked?(value, tag_value)
+ end
+
+ def _pp_select(object, method, collection, priority_collection, options={}, html_options={})
+ return pp_error_on(object, method) do
+ s = ""
+ ## start tag
+ s << "<select id=\"#{object}_#{method}\" name=\"#{object}[#{method}]\""
+ for key, val in html_options:
+ s << " #{key}=\"#{val}\""
+ end
+ s << ">\n"
+ ## selected table
+ key = options.key?(:value) ? :value : (options.key?('value') ? 'value' : nil)
+ if key.nil? ; selected = "@#{object}.#{method}"
+ elsif (val=options[key]).nil? ; selected = nil
+ elsif val =~ /\A<%=(.*)%>\z/ ; selected = $1
+ else ; selected = val.inspect
+ end
+ s << "<% _table = {#{selected}=>' selected=\"selected\"'} %>\n" if selected
+ ## <option> tags
+ if options[:include_blank] || options['include_blank']
+ s << "<option value=\"\"></option>\n"
+ end
+ unless priority_collection.blank?
+ _pp_select_options(s, priority_collection, selected, 'delete')
+ s << "<option value=\"\">-------------</option>\n"
+ end
+ _pp_select_options(s, collection, selected, '[]')
+ ## end tag
+ s << "</select>"
+ s
+ end
+ end
+
+ def _pp_select_options(s, collection, selected, operator)
+ for item in collection
+ value, text = item.is_a?(Array) ? item : [item, item]
+ if !selected
+ t = ''
+ elsif operator == 'delete'
+ t = "<%= _table.delete(#{value.inspect}) %>"
+ else
+ t = "<%= _table[#{value.inspect}] %>"
+ end
+ s << "<option value=\"#{h value}\"#{t}>#{h text}</option>\n"
+ end
+ end
+
+ def pp_select(object, method, collection, options={}, html_options={})
+ return _pp_select(object, method, collection, nil, options, html_options)
+ end
+
+ def pp_collection_select(object, method, collection, value_method, text_method, options={}, html_options={})
+ collection2 = collection.collect { |e|
+ [e.__send__(value_method), e.__send__(text_method)]
+ }
+ return _pp_select(object, method, collection2, nil, options, html_options)
+ end
+
+ def pp_country_select(object, method, priority_countries=nil, options={}, html_options={})
+ collection = ActionView::Helpers::FormOptionsHelper::COUNTRIES
+ return _pp_select(object, method, collection, priority_countries, options, html_options)
+ end
+
+ def pp_time_zone_select(object, method, priority_zones=nil, options={}, html_options={})
+ model = options[:model] || options['model'] || TimeZone
+ collection = model.all.collect { |e| [e.name, e.to_s] }
+ return _pp_select(object, method, collection, priority_zones, options, html_options)
+ end
+
+ def pp_submit_tag(value="Save changes", options={})
+ return submit_tag(value, options)
+ end
+
+ def pp_image_submit_tag(source, options={})
+ return image_submit_tag(source, options)
+ end
+
+end
diff --git a/lib/erubis/helpers/rails_helper.rb b/lib/erubis/helpers/rails_helper.rb
index 79d28bd..a055f85 100644
--- a/lib/erubis/helpers/rails_helper.rb
+++ b/lib/erubis/helpers/rails_helper.rb
@@ -34,15 +34,11 @@ module Erubis
## #Erubis::Helpers::RailsHelper.show_src = false # set true for debugging
## #Erubis::Helpers::RailsHelper.preprocessing = true # set true to enable preprocessing
##
- ## 2. (optional) apply the patch for 'action_view/base.rb'
+ ## 2. restart web server.
##
- ## $ cd /usr/local/lib/ruby/gems/1.8/gems/actionpack-1.13.3/lib/action_view/
- ## $ sudo patch -p1 < /tmp/erubis_2.X.X/contrib/action_view_base_rb.patch
- ##
- ## 3. restart web server.
- ##
- ## if Erubis::Helper::Rails.show_src is ture, Erubis prints converted Ruby code
- ## into log file ('log/development.log' or so). This may be useful for debug.
+ ## if Erubis::Helper::Rails.show_src is true, Erubis prints converted Ruby code
+ ## into log file ('log/development.log' or so). if false, it doesn't.
+ ## if nil, Erubis prints converted Ruby code if ENV['RAILS_ENV'] == 'development'.
##
module RailsHelper
@@ -70,7 +66,7 @@ module Erubis
end
#cattr_accessor :show_src
- @@show_src = false
+ @@show_src = nil
def self.show_src
@@show_src
@@ -80,7 +76,7 @@ module Erubis
@@show_src = flag
end
- ##----- preprocessor: experimental -----
+ ##----- preprocessing --------------------
@@preprocessing = false
def self.preprocessing
@@preprocessing
@@ -126,19 +122,21 @@ unless ActionView::Base.private_instance_methods.include?(method_name) ||
end
-if ActionPack::VERSION::MINOR <= 12 ### Rails 1.1
+if ActionPack::VERSION::MAJOR >= 2 ### Rails 2.X
- # Create source code for given template
+ # Method to create the source code for a given template.
def create_template_source(extension, template, render_symbol, locals)
if template_requires_setup?(extension)
body = case extension.to_sym
- when :rxml
+ when :rxml, :builder
+ content_type_handler = (controller.respond_to?(:response) ? "controller.response" : "controller")
+ "#{content_type_handler}.content_type ||= Mime::XML\n" +
"xml = Builder::XmlMarkup.new(:indent => 2)\n" +
- "@controller.headers['Content-Type'] ||= 'application/xml'\n" +
- template
+ template +
+ "\nxml.target!\n"
when :rjs
- "@controller.headers['Content-Type'] ||= 'text/javascript'\n" +
+ "controller.response.content_type ||= Mime::JS\n" +
"update_page do |page|\n#{template}\nend"
end
else
@@ -152,14 +150,14 @@ if ActionPack::VERSION::MINOR <= 12 ### Rails 1.1
locals_code = ""
locals_keys.each do |key|
- locals_code << "#{key} = local_assigns[:#{key}] if local_assigns.has_key?(:#{key})\n"
+ locals_code << "#{key} = local_assigns[:#{key}]\n"
end
"def #{render_symbol}(local_assigns)\n#{locals_code}#{body}\nend"
end
-else ### Rails 1.2 or later
+elsif ActionPack::VERSION::MINOR > 12 ### Rails 1.2
# Create source code for given template
@@ -192,6 +190,39 @@ else ### Rails 1.2 or later
end
+elsif ActionPack::VERSION::MINOR <= 12 ### Rails 1.1
+
+
+ # Create source code for given template
+ def create_template_source(extension, template, render_symbol, locals)
+ if template_requires_setup?(extension)
+ body = case extension.to_sym
+ when :rxml
+ "xml = Builder::XmlMarkup.new(:indent => 2)\n" +
+ "@controller.headers['Content-Type'] ||= 'application/xml'\n" +
+ template
+ when :rjs
+ "@controller.headers['Content-Type'] ||= 'text/javascript'\n" +
+ "update_page do |page|\n#{template}\nend"
+ end
+ else
+ #body = ERB.new(template, nil, @@erb_trim_mode).src
+ body = convert_template_into_ruby_code(template)
+ end
+
+ @@template_args[render_symbol] ||= {}
+ locals_keys = @@template_args[render_symbol].keys | locals
+ @@template_args[render_symbol] = locals_keys.inject({}) { |h, k| h[k] = true; h }
+
+ locals_code = ""
+ locals_keys.each do |key|
+ locals_code << "#{key} = local_assigns[:#{key}] if local_assigns.has_key?(:#{key})\n"
+ end
+
+ "def #{render_symbol}(local_assigns)\n#{locals_code}#{body}\nend"
+ end
+
+
end ###
@@ -210,10 +241,12 @@ class ActionView::Base # :nodoc:
klass = Erubis::Helpers::RailsHelper.engine_class
properties = Erubis::Helpers::RailsHelper.init_properties
show_src = Erubis::Helpers::RailsHelper.show_src
- ##----- preprocessing: experimental -----
+ show_src = ENV['RAILS_ENV'] == 'development' if show_src.nil?
+ ##----- preprocessing -------------------
if Erubis::Helpers::RailsHelper.preprocessing
preprocessor = Erubis::Helpers::RailsHelper::PreprocessingEruby.new(template)
- template = self.instance_eval(preprocessor.src)
+ #template = self.instance_eval(preprocessor.src)
+ template = preprocessor.evaluate(self)
logger.debug "** Erubis: preprocessed==<<'END'\n#{template}END\n" if show_src
end
##----------------------------------------
@@ -223,12 +256,14 @@ class ActionView::Base # :nodoc:
src
end
- ##----- preprocessing: experimental -----
- def _expr(arg)
+ ##----- preprocessing -------------------
+ def _p(arg)
return "<%=#{arg}%>"
end
- alias _x _expr
- alias _? _expr
+ def _P(arg)
+ return "<%=h(#{arg})%>"
+ end
+ alias _? _p
def _decode(arg)
arg = arg.to_s
arg.gsub!(/%3C%25%3D(.*?)%25%3E/) { "<%=#{CGI.unescape($1)}%>" }