Module: Sinatra::Templates
- Included in:
- Base
- Defined in:
- lib/sinatra/base.rb
Overview
Template rendering methods. Each method takes the name of a template to render as a Symbol and returns a String with the rendered output, as well as an optional hash with additional options.
‘template` is either the name or path of the template as symbol (Use `:’subdir/myview’‘ for views in subdirectories), or a string that will be rendered.
Possible options are:
:content_type The content type to use, same arguments as content_type.
:layout If set to false, no layout is rendered, otherwise
the specified layout is used (Ignored for `sass` and `less`)
:layout_engine Engine to use for rendering the layout.
:locals A hash with local variables that should be available
in the template
:scope If set, template is evaluate with the binding of the given
object rather than the application instance.
:views Views directory to use.
Defined Under Namespace
Modules: ContentTyped
Instance Method Summary collapse
- #builder(template = nil, options = {}, locals = {}, &block) ⇒ Object
- #coffee(template, options = {}, locals = {}) ⇒ Object
- #erb(template, options = {}, locals = {}) ⇒ Object
- #erubis(template, options = {}, locals = {}) ⇒ Object
-
#find_template(views, name, engine) {|::File.join(views, "#{name}.#{@preferred_extension}")| ... } ⇒ Object
Calls the given block for every possible template file in views, named name.ext, where ext is registered on engine.
- #haml(template, options = {}, locals = {}) ⇒ Object
- #less(template, options = {}, locals = {}) ⇒ Object
- #liquid(template, options = {}, locals = {}) ⇒ Object
- #markaby(template = nil, options = {}, locals = {}, &block) ⇒ Object
- #markdown(template, options = {}, locals = {}) ⇒ Object
- #nokogiri(template = nil, options = {}, locals = {}, &block) ⇒ Object
- #radius(template, options = {}, locals = {}) ⇒ Object
- #rdoc(template, options = {}, locals = {}) ⇒ Object
- #sass(template, options = {}, locals = {}) ⇒ Object
- #scss(template, options = {}, locals = {}) ⇒ Object
- #slim(template, options = {}, locals = {}) ⇒ Object
- #textile(template, options = {}, locals = {}) ⇒ Object
Instance Method Details
#builder(template = nil, options = {}, locals = {}, &block) ⇒ Object
481 482 483 484 |
# File 'lib/sinatra/base.rb', line 481 def builder(template=nil, ={}, locals={}, &block) [:default_content_type] = :xml render_ruby(:builder, template, , locals, &block) end |
#coffee(template, options = {}, locals = {}) ⇒ Object
510 511 512 513 |
# File 'lib/sinatra/base.rb', line 510 def coffee(template, ={}, locals={}) .merge! :layout => false, :default_content_type => :js render :coffee, template, , locals end |
#erb(template, options = {}, locals = {}) ⇒ Object
454 455 456 |
# File 'lib/sinatra/base.rb', line 454 def erb(template, ={}, locals={}) render :erb, template, , locals end |
#erubis(template, options = {}, locals = {}) ⇒ Object
458 459 460 |
# File 'lib/sinatra/base.rb', line 458 def erubis(template, ={}, locals={}) render :erubis, template, , locals end |
#find_template(views, name, engine) {|::File.join(views, "#{name}.#{@preferred_extension}")| ... } ⇒ Object
Calls the given block for every possible template file in views, named name.ext, where ext is registered on engine.
526 527 528 529 530 531 532 |
# File 'lib/sinatra/base.rb', line 526 def find_template(views, name, engine) yield ::File.join(views, "#{name}.#{@preferred_extension}") Tilt.mappings.each do |ext, engines| next unless ext != @preferred_extension and Array(engines).include? engine yield ::File.join(views, "#{name}.#{ext}") end end |
#haml(template, options = {}, locals = {}) ⇒ Object
462 463 464 |
# File 'lib/sinatra/base.rb', line 462 def haml(template, ={}, locals={}) render :haml, template, , locals end |
#less(template, options = {}, locals = {}) ⇒ Object
476 477 478 479 |
# File 'lib/sinatra/base.rb', line 476 def less(template, ={}, locals={}) .merge! :layout => false, :default_content_type => :css render :less, template, , locals end |
#liquid(template, options = {}, locals = {}) ⇒ Object
486 487 488 |
# File 'lib/sinatra/base.rb', line 486 def liquid(template, ={}, locals={}) render :liquid, template, , locals end |
#markaby(template = nil, options = {}, locals = {}, &block) ⇒ Object
506 507 508 |
# File 'lib/sinatra/base.rb', line 506 def markaby(template=nil, ={}, locals={}, &block) render_ruby(:mab, template, , locals, &block) end |
#markdown(template, options = {}, locals = {}) ⇒ Object
490 491 492 |
# File 'lib/sinatra/base.rb', line 490 def markdown(template, ={}, locals={}) render :markdown, template, , locals end |
#nokogiri(template = nil, options = {}, locals = {}, &block) ⇒ Object
515 516 517 518 |
# File 'lib/sinatra/base.rb', line 515 def nokogiri(template=nil, ={}, locals={}, &block) [:default_content_type] = :xml render_ruby(:nokogiri, template, , locals, &block) end |
#radius(template, options = {}, locals = {}) ⇒ Object
502 503 504 |
# File 'lib/sinatra/base.rb', line 502 def radius(template, ={}, locals={}) render :radius, template, , locals end |
#rdoc(template, options = {}, locals = {}) ⇒ Object
498 499 500 |
# File 'lib/sinatra/base.rb', line 498 def rdoc(template, ={}, locals={}) render :rdoc, template, , locals end |
#sass(template, options = {}, locals = {}) ⇒ Object
466 467 468 469 |
# File 'lib/sinatra/base.rb', line 466 def sass(template, ={}, locals={}) .merge! :layout => false, :default_content_type => :css render :sass, template, , locals end |
#scss(template, options = {}, locals = {}) ⇒ Object
471 472 473 474 |
# File 'lib/sinatra/base.rb', line 471 def scss(template, ={}, locals={}) .merge! :layout => false, :default_content_type => :css render :scss, template, , locals end |
#slim(template, options = {}, locals = {}) ⇒ Object
520 521 522 |
# File 'lib/sinatra/base.rb', line 520 def slim(template, ={}, locals={}) render :slim, template, , locals end |
#textile(template, options = {}, locals = {}) ⇒ Object
494 495 496 |
# File 'lib/sinatra/base.rb', line 494 def textile(template, ={}, locals={}) render :textile, template, , locals end |