来自rails引擎的Sass导入无法正常工作

Bra*_*don 8 ruby-on-rails sass rails-engines asset-pipeline ruby-on-rails-4.1

我为资产创建了一个Rails引擎.我不使用链轮用于css.相反,我依赖sass的@import.这在测试/虚拟应用程序中完全正常,但在需要引擎的Rails应用程序中,它一直在投掷

Sass::SyntaxError: File to import not found or unreadable: gumby.
Run Code Online (Sandbox Code Playgroud)

我已经在这一段时间了,原来路径不在sass的加载路径中.但后来我补充道

config.sass.load_paths << "#{Gem.loaded_specs['gumby_on_rails'].full_gem_path}/app/assets/stylesheets"
Run Code Online (Sandbox Code Playgroud)

到我config/application.rb现在它肯定显示我正在尝试导入的文件的正确路径.它是以下跟踪中列出的最后一个路径的第二个:

Sass::SyntaxError: File to import not found or unreadable: gumby.
Load paths:
  CompassRails::SpriteImporter
  CompassRails::SpriteImporter
  CompassRails::SpriteImporter
  CompassRails::SpriteImporter
  CompassRails::SpriteImporter
  CompassRails::SpriteImporter
  CompassRails::SpriteImporter
  CompassRails::SpriteImporter
  CompassRails::SpriteImporter
  /Users/brandon/code/personal/blog_update/app/assets/images
  /Users/brandon/code/personal/blog_update/app/assets/javascripts
  /Users/brandon/code/personal/blog_update/app/assets/stylesheets
  /Users/brandon/code/personal/blog_update/vendor/assets/javascripts
  /Users/brandon/code/personal/blog_update/vendor/assets/stylesheets
  /Users/brandon/.rvm/gems/jruby-1.7.11@blog/gems/angularjs-rails-1.0.7/vendor/assets/javascripts
  /Users/brandon/.rvm/gems/jruby-1.7.11@blog/gems/turbolinks-2.2.2/lib/assets/javascripts
  /Users/brandon/.rvm/gems/jruby-1.7.11@blog/gems/jquery-rails-3.1.0/vendor/assets/javascripts
  /Users/brandon/.rvm/gems/jruby-1.7.11@blog/gems/coffee-rails-4.0.1/lib/assets/javascripts
  /Users/brandon/code/personal/gumby/app/assets/stylesheets
  /Users/brandon/code/personal/blog_update/app/assets/stylesheets
Run Code Online (Sandbox Code Playgroud)

rails引擎的树看起来像这样

app/
  assets/
    stylesheets/
      gumby/
        ...
      gumby.css.scss
Run Code Online (Sandbox Code Playgroud)

(我知道从技术上讲,你应该将所有资产命名为引擎,但我不想使用gumby/gumby,我觉得名字冲突的可能性很小.)

所以在测试/虚拟应用程序中,我可以通过导入此文件@import 'gumby';,但这在Rails应用程序中失败.有了上述例外.我该如何工作?

顺便说一句,这是一个Rails 4.1应用程序,其他几个"类似"问题的答案都是由于在Gemfile中使用组.Rails 4摆脱了组,所以这不是问题/解决方案.

Bra*_*don 3

所以我的解决方案是吸收它并命名它gumby/gumby。然后我还必须将其更改config/application.rb为:

config.assets.paths << "#{Gem.loaded_specs['gumby_on_rails'].full_gem_path}/app/assets/stylesheets"
Run Code Online (Sandbox Code Playgroud)

由于某种原因modular-scale,即使引擎已经需要它,也没有正确地需要它。所以我不得不改为application.css.scssapplication.css.scss.erb放在<% require 'modular-scale' %>顶部。