Allow layouts to be disabled entirely

This commit is contained in:
Thomas Reynolds 2011-07-08 15:01:57 -07:00
parent daf217567f
commit 0b9ea13364
3 changed files with 22 additions and 15 deletions

View file

@ -136,6 +136,9 @@ module Middleman
# Proxy web services requests in dev mode only
autoload :Proxy, "middleman/features/proxy"
# Sprockets 2
# autoload :Sprockets, "middleman/features/sprockets"
# Automatically resize images for mobile devises
# autoload :TinySrc, "middleman/features/tiny_src"

View file

@ -11,11 +11,7 @@ module Middleman::CoreExtensions::Routing
alias :included :registered
end
module ClassMethods
def current_layout
@layout
end
module ClassMethods
def path_to_index(path)
parts = path ? path.split('/') : []
if parts.last.nil? || parts.last.split('.').length == 1
@ -30,12 +26,12 @@ module Middleman::CoreExtensions::Routing
# page "/admin/login.html"
# end
def with_layout(layout_name, &block)
old_layout = current_layout
old_layout = settings.layout
layout(layout_name)
set :layout, layout_name
class_eval(&block) if block_given?
ensure
layout(old_layout)
set :layout, old_layout
end
# The page method allows the layout to be set on a specific path
@ -49,7 +45,7 @@ module Middleman::CoreExtensions::Routing
paths << "#{url}/" if url.length > 1 && url.split("/").last.split('.').length <= 1
paths << "#{path_to_index(url)}"
options[:layout] = current_layout if options[:layout].nil?
options[:layout] = settings.layout if options[:layout].nil?
paths.each do |p|
get(p) do

View file

@ -64,7 +64,7 @@ module Middleman
end
# Default layout name
layout :layout
set :layout, :layout
# This will match all requests not overridden in the project's config.rb
not_found do
@ -98,15 +98,23 @@ module Middleman
options.merge!(request['custom_options'] || {})
old_layout = settings.current_layout
settings.layout(options[:layout]) if !options[:layout].nil?
layout = settings.fetch_layout_path.to_sym
layout = false if options[:layout] == false or request.path_info =~ /\.(css|js)$/
old_layout = settings.layout
settings.set :layout, options[:layout] if !options[:layout].nil?
layout = if settings.layout
if options[:layout] == false || request.path_info =~ /\.(css|js)$/
false
else
settings.fetch_layout_path(settings.layout).to_sym
end
else
false
end
render_options = { :layout => layout }
render_options[:layout_engine] = options[:layout_engine] if options.has_key? :layout_engine
result = render(request.path_info, render_options)
settings.layout(old_layout)
settings.set :layout, old_layout
if result
content_type mime_type(File.extname(request.path_info)), :charset => 'utf-8'