Thorを介して起動されたSinatraアプリが組み込まれたライブラリを作成しています。Sprockets::Environment
at/css
とのインスタンスをマウント/js
し、メインアプリをにマップしたいと思います/
。これはファイルで簡単に使用できますが、この場合、Sinatraアプリをプログラムで起動しているため、ファイルはありませRack::URLMap
ん。どうすればこれを達成できますか?config.ru
Sinatra::Application.run!
3 に答える
実際、これはそれほど難しいことではありません。必要なのは、のインスタンスをSprockets::Environment
Sinatra構成変数に割り当て、関心のあるアセットを検索するためのパスを定義することだけです。
基本的な例は次のとおりです。
require "sass"
require "haml"
require "erubis"
require "sinatra"
require "sprockets"
set :assets, Sprockets::Environment.new
# Configure sprockets
settings.assets.append_path "app/javascripts"
settings.assets.append_path "app/stylesheets"
# For compressed JS and CSS output
require "yui/compressor"
settings.assets.js_compressor = YUI::JavaScriptCompressor.new
settings.assets.css_compressor = YUI::CssCompressor.new
get "/" do
haml :index
end
get "/javascripts/:file.js" do
content_type "application/javascript"
settings.assets["#{params[:file]}.js"]
end
get "/stylesheets/:file.css" do
content_type "text/css"
settings.assets["#{params[:file]}.css"]
end
ハッピースプロケット!
の機能の一部を備えたカスタムミドルウェアを作成することで、最終的にそれを実行しましたRack::URLMap
。おおまかに次のようになります。
require "sprockets"
require "sinatra/base"
class SprocketsMiddleware
attr_reader :app, :prefix, :sprockets
def initialize(app, prefix)
@app = app
@prefix = prefix
@sprockets = Sprockets::Environment.new
yield sprockets if block_given?
end
def call(env)
path_info = env["PATH_INFO"]
if path_info =~ prefix
env["PATH_INFO"].sub!(prefix, "")
sprockets.call(env)
else
app.call(env)
end
ensure
env["PATH_INFO"] = path_info
end
end
class App < Sinatra::Base
use SprocketsMiddleware, %r{/assets} do |env|
env.append_path "assets/css"
env.append_path "assets/js"
end
end
App.run!
これが、SprocketsをRailsのようなディレクトリレイアウト、ヘルパー、JSとCSSの縮小化を使用してSinatraに統合した方法です。
私はSinatra拡張機能を作成することにしました。この拡張機能は、スプロケットの構成(パス、ミニファイ、ヘルパー)をカプセル化し、アプリケーションで登録できます。
module Sinatra
module Assets
extend Sinatra::Extension
configure do
set :assets, Sprockets::Environment.new(root).tap { |assets|
%w(assets vendor/assets).each do |base|
%w(images javascripts stylesheets).each do |type|
assets.append_path File.join(base, type)
end
end
if production?
assets.js_compressor = Closure::Compiler.new
assets.css_compressor = YUI::CssCompressor.new
uid = Digest::MD5.hexdigest(File.dirname(__FILE__))[0,8]
assets.cache = Sprockets::Cache::FileStore.new("/tmp/sinatra-#{uid}")
else
assets.cache = nil
end
}
end
get "/assets/*" do
env["PATH_INFO"].sub!(%r{^/assets}, "")
expires Time.now + (365*24*60*60) if settings.production?
settings.assets.call(env)
end
helpers do
include Sprockets::Helpers
Sprockets::Helpers.configure do |config|
config.expand = development?
config.digest = production?
end
def assets_environment
settings.assets
end
end
end
end
アプリケーションで拡張機能を使用するのは簡単です。
class App < Sinatra::Base
register Sinatra::Assets
# ...
end
assets
アセットは、、またはに配置できますvendor/assets
。たとえばvendor/assets/jquery.js
、論理名、つまり。で参照できますhttp://localhost/assets/jquery.js
。
上記の例では、などのヘルパーを提供するsprockets-helpersjavascript_tag
を使用しています。上記の構成は、開発時に、参照されるアセットに必要なアセットを拡張することを前提としています(アセットごとに複数のタグが作成されます)。