This package is used to easily precompile Sass files within Stencil components. Internally this plugin uses node-sass.
This package is a fork of @stencil/sass to work around problems with the bundled sass implementation
First, npm install within the project:
npm install stencil-node-sass node-sass --save-dev
Or with yarn:
yarn add stencil-node-sass node-sass --dev
Next, within the project's stencil config, import the plugin and add it to the config's plugins
property:
import { Config } from '@stencil/core';
import { sass } from 'stencil-node-sass';
export const config: Config = {
plugins: [
sass()
]
};
During development, this plugin will kick-in for .scss
or .sass
style urls, and precompile them to CSS.
Sass options can be passed to the plugin within the stencil config, which are used directly by sass
. Please reference sass documentation for all available options. Note that this plugin automatically adds the component's directory to the includePaths
array.
The injectGlobalPaths
config is an array of paths that automatically get added as @import
declarations to all components. This can be useful to inject Sass variables, mixins and functions to override defaults of external collections. For example, apps can override default Sass variables of Ionic components. Relative paths within injectGlobalPaths
should be relative to the stencil config file.
exports.config = {
plugins: [
sass({
injectGlobalPaths: [
'src/globals/variables.scss',
'src/globals/mixins.scss'
]
})
]
};
Note that each of these files are always added to each component, so in most cases they shouldn't contain CSS because it'll get duplicated in each component. Instead, injectGlobalPaths
should only be used for Sass variables, mixins and functions, but does not contain any CSS.
The heavy lifting was done by the ionic-team i just changed the imports to node-sass. So all credits belongs to the ionic-team.