J'ai un fichier scss distinct pour chaque contrôleur et je ne les importe pas tous dans le fichier application.css afin de pouvoir inclure la feuille de style et le fichier js spécifiques au contrôleur dans la mise en page.
Donc, dans la mise en page, je le fais :
<%= stylesheet_link_tag "application" %>
<%= stylesheet_link_tag params[:controller], :media => "all" %>
<%= javascript_include_tag 'application' %>
<%= javascript_include_tag params[:controller] %>
Mais lorsque j'exécute rake assets:precompile, je n'obtiens pas de ressources compilées pour les contrôleurs.
J'ai cherché des solutions sur le web, mais elles indiquaient toutes d'ajouter les fichiers nécessaires au staitment config.assets.precompile. Et je ne sais pas quoi mettre là pour que tous les actifs dans les sous-dossiers de app/assets/stylesheets et les sous-dossiers de app/assets/javascripts soient compilés automatiquement.
MISE À JOUR 1
OK, je vais les compiler dans un seul fichier, mais il y a deux problèmes :
-
J'ai un fichier _base.scss contenant toutes les variables et importations nécessaires, et j'ai renommé application.css en application.css.scss afin de pouvoir importer ce fichier avant tout le reste :
@import 'base'; @import 'style'; @import 'forms';
Comment dois-je procéder avec un manifeste ? Je n'ai pas trouvé de moyen d'importer le répertoire entier avec scss lui-même.
- J'ai des actions différentes pour les mêmes sélecteurs dans différents contrôleurs. Quel est le moyen le plus simple de séparer ces actions et de définir ce qui doit être traité sur une page particulière ?