fix relative assets and sprockets js

This commit is contained in:
Thomas Reynolds 2011-11-18 17:37:01 -08:00
parent 7d9550e9ce
commit 4ceb9bab41
5 changed files with 36 additions and 46 deletions

View file

@ -218,7 +218,7 @@ class Middleman::Base
@current_path = @request_path.dup @current_path = @request_path.dup
path, engine = found_template path, engine = found_template
# Static File # Static File
return send_file(path) if engine.nil? return send_file(path) if engine.nil?

View file

@ -27,11 +27,6 @@ module Middleman::CoreExtensions::DefaultHelpers
end end
module Helpers module Helpers
# TODO: Implement
def javascript_include_tag(path)
end
def auto_stylesheet_link_tag(separator="/") def auto_stylesheet_link_tag(separator="/")
auto_tag(:css, separator) do |path| auto_tag(:css, separator) do |path|
stylesheet_link_tag path stylesheet_link_tag path

View file

@ -38,7 +38,7 @@ module Middleman::CoreExtensions::Sprockets
end end
# add paths to js_env (vendor/assets/javascripts) # add paths to js_env (vendor/assets/javascripts)
app.map "/#{self.js_dir}" do map "/#{self.js_dir}" do
run js_env run js_env
end end
end end
@ -70,10 +70,7 @@ module Middleman::CoreExtensions::Sprockets
class MiddlemanEnvironment < ::Sprockets::Environment class MiddlemanEnvironment < ::Sprockets::Environment
def initialize(app) def initialize(app)
full_path = app.views super app.source_dir
full_path = File.join(app.root, app.views) unless app.views.include?(app.root)
super File.expand_path(full_path)
# Make the app context available to Sprockets # Make the app context available to Sprockets
context_class.send(:define_method, :app) { app } context_class.send(:define_method, :app) { app }
@ -92,12 +89,9 @@ module Middleman::CoreExtensions::Sprockets
class JavascriptEnvironment < MiddlemanEnvironment class JavascriptEnvironment < MiddlemanEnvironment
def initialize(app) def initialize(app)
super super
# Disable css
# unregister_processor "text/css", ::Sprockets::DirectiveProcessor
self.js_compressor = app.js_compressor self.js_compressor = app.js_compressor
# configure search paths # configure search paths
append_path app.js_dir append_path app.js_dir
end end
@ -111,9 +105,6 @@ module Middleman::CoreExtensions::Sprockets
class StylesheetEnvironment < MiddlemanEnvironment class StylesheetEnvironment < MiddlemanEnvironment
def initialize(app) def initialize(app)
super super
# Disable js
# unregister_processor "application/javascript", ::Sprockets::DirectiveProcessor
self.css_compressor = app.css_compressor self.css_compressor = app.css_compressor

View file

@ -4,35 +4,39 @@ module Middleman::Features::RelativeAssets
app.compass_config do |config| app.compass_config do |config|
config.relative_assets = true config.relative_assets = true
end end
app.register_asset_handler :relative_assets do |path, prefix| app.send :include, InstanceMethods
begin
prefix = self.images_dir if prefix == self.http_images_path
rescue
end
if path.include?("://")
self.before_asset_handler(:relative_assets, path, prefix)
elsif path[0,1] == "/"
path
else
path = File.join(prefix, path) if prefix.length > 0
request_path = @request_path.dup
request_path << self.index_file if path.match(%r{/$})
request_path.gsub!(%r{^/}, '')
parts = request_path.split('/')
if parts.length > 1
arry = []
(parts.length - 1).times { arry << ".." }
arry << path
File.join(*arry)
else
path
end
end
end
end end
alias :included :registered alias :included :registered
end end
module InstanceMethods
def asset_url(path, prefix="")
begin
prefix = self.images_dir if prefix == self.http_images_path
rescue
end
if path.include?("://")
super(path, prefix)
elsif path[0,1] == "/"
path
else
path = File.join(prefix, path) if prefix.length > 0
request_path = @request_path.dup
request_path << self.index_file if path.match(%r{/$})
request_path.gsub!(%r{^/}, '')
parts = request_path.split('/')
if parts.length > 1
arry = []
(parts.length - 1).times { arry << ".." }
arry << path
File.join(*arry)
else
path
end
end
end
end
end end