mirror of
https://github.com/codeninjasllc/discourse.git
synced 2024-11-23 23:58:31 -05:00
Move register_asset
into PluginRegistry
-- the logic works better
there.
This commit is contained in:
parent
2b817f826b
commit
663cd93c6d
4 changed files with 103 additions and 99 deletions
|
@ -68,6 +68,34 @@ class DiscoursePluginRegistry
|
||||||
Archetype.register(name, options)
|
Archetype.register(name, options)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def self.register_asset(asset, opts=nil)
|
||||||
|
if asset =~ /\.js$|\.js\.erb$|\.js\.es6$/
|
||||||
|
if opts == :admin
|
||||||
|
self.admin_javascripts << asset
|
||||||
|
else
|
||||||
|
if opts == :server_side
|
||||||
|
self.server_side_javascripts << asset
|
||||||
|
end
|
||||||
|
self.javascripts << asset
|
||||||
|
end
|
||||||
|
elsif asset =~ /\.css$|\.scss$/
|
||||||
|
if opts == :mobile
|
||||||
|
self.mobile_stylesheets << asset
|
||||||
|
elsif opts == :desktop
|
||||||
|
self.desktop_stylesheets << asset
|
||||||
|
elsif opts == :variables
|
||||||
|
self.sass_variables << asset
|
||||||
|
else
|
||||||
|
self.stylesheets << asset
|
||||||
|
end
|
||||||
|
|
||||||
|
elsif asset =~ /\.hbs$/
|
||||||
|
self.handlebars << asset
|
||||||
|
elsif asset =~ /\.js\.handlebars$/
|
||||||
|
self.handlebars << asset
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def javascripts
|
def javascripts
|
||||||
self.class.javascripts
|
self.class.javascripts
|
||||||
end
|
end
|
||||||
|
@ -106,6 +134,17 @@ class DiscoursePluginRegistry
|
||||||
self.handlebars = nil
|
self.handlebars = nil
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def self.reset!
|
||||||
|
javascripts.clear
|
||||||
|
admin_javascripts.clear
|
||||||
|
server_side_javascripts.clear
|
||||||
|
stylesheets.clear
|
||||||
|
mobile_stylesheets.clear
|
||||||
|
desktop_stylesheets.clear
|
||||||
|
sass_variables.clear
|
||||||
|
serialized_current_user_fields
|
||||||
|
end
|
||||||
|
|
||||||
def self.setup(plugin_class)
|
def self.setup(plugin_class)
|
||||||
registry = DiscoursePluginRegistry.new
|
registry = DiscoursePluginRegistry.new
|
||||||
plugin = plugin_class.new(registry)
|
plugin = plugin_class.new(registry)
|
||||||
|
|
|
@ -40,7 +40,6 @@ class Plugin::Instance
|
||||||
register_asset(relative)
|
register_asset(relative)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def name
|
def name
|
||||||
|
@ -186,7 +185,6 @@ class Plugin::Instance
|
||||||
Rails.configuration.assets.paths << File.dirname(path) + "/assets"
|
Rails.configuration.assets.paths << File.dirname(path) + "/assets"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
public_data = File.dirname(path) + "/public"
|
public_data = File.dirname(path) + "/public"
|
||||||
if Dir.exists?(public_data)
|
if Dir.exists?(public_data)
|
||||||
target = Rails.root.to_s + "/public/plugins/"
|
target = Rails.root.to_s + "/public/plugins/"
|
||||||
|
@ -243,31 +241,7 @@ class Plugin::Instance
|
||||||
|
|
||||||
def register_assets!
|
def register_assets!
|
||||||
assets.each do |asset, opts|
|
assets.each do |asset, opts|
|
||||||
if asset =~ /\.js$|\.js\.erb$|\.js\.es6$/
|
DiscoursePluginRegistry.register_asset(asset, opts)
|
||||||
if opts == :admin
|
|
||||||
DiscoursePluginRegistry.admin_javascripts << asset
|
|
||||||
else
|
|
||||||
if opts == :server_side
|
|
||||||
DiscoursePluginRegistry.server_side_javascripts << asset
|
|
||||||
end
|
|
||||||
DiscoursePluginRegistry.javascripts << asset
|
|
||||||
end
|
|
||||||
elsif asset =~ /\.css$|\.scss$/
|
|
||||||
if opts == :mobile
|
|
||||||
DiscoursePluginRegistry.mobile_stylesheets << asset
|
|
||||||
elsif opts == :desktop
|
|
||||||
DiscoursePluginRegistry.desktop_stylesheets << asset
|
|
||||||
elsif opts == :variables
|
|
||||||
DiscoursePluginRegistry.sass_variables << asset
|
|
||||||
else
|
|
||||||
DiscoursePluginRegistry.stylesheets << asset
|
|
||||||
end
|
|
||||||
|
|
||||||
elsif asset =~ /\.hbs$/
|
|
||||||
DiscoursePluginRegistry.handlebars << asset
|
|
||||||
elsif asset =~ /\.js\.handlebars$/
|
|
||||||
DiscoursePluginRegistry.handlebars << asset
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -82,4 +82,65 @@ describe DiscoursePluginRegistry do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context '#register_asset' do
|
||||||
|
let(:registry) { DiscoursePluginRegistry }
|
||||||
|
|
||||||
|
after do
|
||||||
|
registry.reset!
|
||||||
|
end
|
||||||
|
|
||||||
|
it "does register general css properly" do
|
||||||
|
registry.register_asset("test.css")
|
||||||
|
registry.register_asset("test2.css")
|
||||||
|
|
||||||
|
registry.mobile_stylesheets.count.should == 0
|
||||||
|
registry.stylesheets.count.should == 2
|
||||||
|
end
|
||||||
|
|
||||||
|
it "registers desktop css properly" do
|
||||||
|
registry.register_asset("test.css", :desktop)
|
||||||
|
|
||||||
|
registry.mobile_stylesheets.count.should == 0
|
||||||
|
registry.desktop_stylesheets.count.should == 1
|
||||||
|
registry.stylesheets.count.should == 0
|
||||||
|
end
|
||||||
|
|
||||||
|
it "registers mobile css properly" do
|
||||||
|
registry.register_asset("test.css", :mobile)
|
||||||
|
|
||||||
|
registry.mobile_stylesheets.count.should == 1
|
||||||
|
registry.stylesheets.count.should == 0
|
||||||
|
end
|
||||||
|
|
||||||
|
it "registers desktop css properly" do
|
||||||
|
registry.register_asset("test.css", :desktop)
|
||||||
|
|
||||||
|
registry.desktop_stylesheets.count.should == 1
|
||||||
|
registry.stylesheets.count.should == 0
|
||||||
|
end
|
||||||
|
|
||||||
|
it "registers sass variable properly" do
|
||||||
|
registry.register_asset("test.css", :variables)
|
||||||
|
|
||||||
|
registry.sass_variables.count.should == 1
|
||||||
|
registry.stylesheets.count.should == 0
|
||||||
|
end
|
||||||
|
|
||||||
|
it "registers admin javascript properly" do
|
||||||
|
registry.register_asset("my_admin.js", :admin)
|
||||||
|
|
||||||
|
registry.admin_javascripts.count.should == 1
|
||||||
|
registry.javascripts.count.should == 0
|
||||||
|
registry.server_side_javascripts.count.should == 0
|
||||||
|
end
|
||||||
|
|
||||||
|
it "registers server side javascript properly" do
|
||||||
|
registry.register_asset("my_admin.js", :server_side)
|
||||||
|
|
||||||
|
registry.server_side_javascripts.count.should == 1
|
||||||
|
registry.javascripts.count.should == 1
|
||||||
|
registry.admin_javascripts.count.should == 0
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,14 +4,7 @@ require_dependency 'plugin/instance'
|
||||||
describe Plugin::Instance do
|
describe Plugin::Instance do
|
||||||
|
|
||||||
after do
|
after do
|
||||||
DiscoursePluginRegistry.javascripts.clear
|
DiscoursePluginRegistry.reset!
|
||||||
DiscoursePluginRegistry.admin_javascripts.clear
|
|
||||||
DiscoursePluginRegistry.server_side_javascripts.clear
|
|
||||||
DiscoursePluginRegistry.stylesheets.clear
|
|
||||||
DiscoursePluginRegistry.mobile_stylesheets.clear
|
|
||||||
DiscoursePluginRegistry.desktop_stylesheets.clear
|
|
||||||
DiscoursePluginRegistry.sass_variables.clear
|
|
||||||
DiscoursePluginRegistry.serialized_current_user_fields
|
|
||||||
end
|
end
|
||||||
|
|
||||||
context "find_all" do
|
context "find_all" do
|
||||||
|
@ -31,7 +24,7 @@ describe Plugin::Instance do
|
||||||
end
|
end
|
||||||
|
|
||||||
context "register asset" do
|
context "register asset" do
|
||||||
it "does register general css properly" do
|
it "populates the DiscoursePluginRegistry" do
|
||||||
plugin = Plugin::Instance.new nil, "/tmp/test.rb"
|
plugin = Plugin::Instance.new nil, "/tmp/test.rb"
|
||||||
plugin.register_asset("test.css")
|
plugin.register_asset("test.css")
|
||||||
plugin.register_asset("test2.css")
|
plugin.register_asset("test2.css")
|
||||||
|
@ -41,71 +34,8 @@ describe Plugin::Instance do
|
||||||
DiscoursePluginRegistry.mobile_stylesheets.count.should == 0
|
DiscoursePluginRegistry.mobile_stylesheets.count.should == 0
|
||||||
DiscoursePluginRegistry.stylesheets.count.should == 2
|
DiscoursePluginRegistry.stylesheets.count.should == 2
|
||||||
end
|
end
|
||||||
|
|
||||||
it "registers desktop css properly" do
|
|
||||||
plugin = Plugin::Instance.new nil, "/tmp/test.rb"
|
|
||||||
plugin.register_asset("test.css", :desktop)
|
|
||||||
plugin.send :register_assets!
|
|
||||||
|
|
||||||
DiscoursePluginRegistry.mobile_stylesheets.count.should == 0
|
|
||||||
DiscoursePluginRegistry.desktop_stylesheets.count.should == 1
|
|
||||||
DiscoursePluginRegistry.stylesheets.count.should == 0
|
|
||||||
end
|
|
||||||
|
|
||||||
it "registers mobile css properly" do
|
|
||||||
plugin = Plugin::Instance.new nil, "/tmp/test.rb"
|
|
||||||
plugin.register_asset("test.css", :mobile)
|
|
||||||
plugin.send :register_assets!
|
|
||||||
|
|
||||||
DiscoursePluginRegistry.mobile_stylesheets.count.should == 1
|
|
||||||
DiscoursePluginRegistry.stylesheets.count.should == 0
|
|
||||||
end
|
|
||||||
|
|
||||||
it "registers desktop css properly" do
|
|
||||||
plugin = Plugin::Instance.new nil, "/tmp/test.rb"
|
|
||||||
plugin.register_asset("test.css", :desktop)
|
|
||||||
plugin.send :register_assets!
|
|
||||||
|
|
||||||
DiscoursePluginRegistry.desktop_stylesheets.count.should == 1
|
|
||||||
DiscoursePluginRegistry.stylesheets.count.should == 0
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
it "registers sass variable properly" do
|
|
||||||
plugin = Plugin::Instance.new nil, "/tmp/test.rb"
|
|
||||||
plugin.register_asset("test.css", :variables)
|
|
||||||
plugin.send :register_assets!
|
|
||||||
|
|
||||||
DiscoursePluginRegistry.sass_variables.count.should == 1
|
|
||||||
DiscoursePluginRegistry.stylesheets.count.should == 0
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
it "registers admin javascript properly" do
|
|
||||||
plugin = Plugin::Instance.new nil, "/tmp/test.rb"
|
|
||||||
plugin.register_asset("my_admin.js", :admin)
|
|
||||||
|
|
||||||
plugin.send :register_assets!
|
|
||||||
|
|
||||||
DiscoursePluginRegistry.admin_javascripts.count.should == 1
|
|
||||||
DiscoursePluginRegistry.javascripts.count.should == 0
|
|
||||||
DiscoursePluginRegistry.server_side_javascripts.count.should == 0
|
|
||||||
end
|
|
||||||
|
|
||||||
it "registers server side javascript properly" do
|
|
||||||
plugin = Plugin::Instance.new nil, "/tmp/test.rb"
|
|
||||||
plugin.register_asset("my_admin.js", :server_side)
|
|
||||||
|
|
||||||
plugin.send :register_assets!
|
|
||||||
|
|
||||||
DiscoursePluginRegistry.server_side_javascripts.count.should == 1
|
|
||||||
DiscoursePluginRegistry.javascripts.count.should == 1
|
|
||||||
DiscoursePluginRegistry.admin_javascripts.count.should == 0
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
context "activate!" do
|
context "activate!" do
|
||||||
it "can activate plugins correctly" do
|
it "can activate plugins correctly" do
|
||||||
plugin = Plugin::Instance.new
|
plugin = Plugin::Instance.new
|
||||||
|
|
Loading…
Reference in a new issue