Custom importer for node-sass to help resolve relative paths to node modules and bower components.
This importer will attempt to resolve sass references using an npm module style algorithm. If the path can't be resolved and the reference starts with node_modules or bower_components, it will walk up the ancestor tree looking for the file. All other references will be ignored and left to be handled by some other custom importer or the regular sass path resolution process.
Note: Node v18 required, i.e. this will not work with earlier versions of Node (and might not work with later versions also). Using Node Version Manager (NVM) recommended.
Install via NPM:
npm install frau-sass-importer
- In your .scss file @import statements, reference another .scss file from a dependent node module or bower component. Examples:
@import 'my-module/src/main.scss';
@import 'my-module/src/main';
@import 'node_modules/my-module/src/widget/widget.scss';
@import 'bower_components/my-component/main.scss';
- Add the custom importer to your node-sass build step.
package.json
{
"scripts": {
"build:css": "node-sass --importer ./node_modules/frau-sass-importer/ ./src/app.scss > ./dist/app.css"
}
}
This project uses mocha, chai, and sinon for unit testing. To run the tests:
npm test
Contributions are welcome, please submit a pull request!
This repository is configured with EditorConfig rules and contributions should make use of them.
This repo is configured to use semantic-release
. Commits prefixed with fix:
and feat:
will trigger patch and minor releases when merged to main
.
To learn how to create major releases and release from maintenance branches, refer to the semantic-release GitHub Action documentation.