Sass-transformer for pub-serve and pub-build.
Simply add the following lines to your pubspec.yaml
:
:::yaml
dependencies:
sass: any
transformers:
- sass
After adding the transformer your .sass
and .scss
files will be automatically transformed to
corresponding .css
files.
You need to have Sass installed and available on the path.
You can also pass options to Sass if necessary:
:::yaml
transformers:
- sass:
executable: /path/to/sass # Sass executable to use
compass: true # Include compass
line-numbers: true # Include line numbers in output
style: compact # Style of generated CSS
copy-sources: true # Copy original .scss/.sass files to output directory
You can use SassC instead of normal Sass by specifying executable as 'sassc' (or any path ending with 'sassc'):
:::yaml
transformers:
- sass:
executable: sassc # or /path/to/sassc
SassC only supports .scss
-files and does not support Compass.
Normally the transformer simply asks Sass to process the primary input files and Sass will then read the dependent inputs from file system. However, if the input files for Sass are themselves produced by other transformers, they might not exist on the file system at all. The normal transformer will not work in those cases.
To work around this problem, you can use inlined_sass_transformer
. It will use Barback's APIs
to read and inline all imports into one big Sass file which it will then pass to Sass.
The downside is that line numbers on error messages and source maps might be incorrect. (See
Issue #4
for details.)
To enable the use of inlined transformer, use sass/inlined_sass_transformer
as your transformer:
::yaml
transformers:
- sass/inlined_sass_transformer
<possible configuration settings>
- UTF8-encoding is assumed for all input files.
Add this script to your path
#!/bin/sh
IN_FILE=$1 # needs to be the first argument
#OUT_FILE=${IN_FILE%.scss}.css
echo File: ${IN_FILE} ==> ${OUT_FILE}
#shift
docker run --rm -i -v $(pwd):/prj
-v ${HOME}/.pub-cache:${HOME}/.pub-cache
-v ${HOME}/dart/bwu_ng_elements/lib:/bwu_ng_elements
-w=/prj zoechi/dart-sass
node-sass
--importer=/usr/local/lib/node_modules/bwu_dart_node_sass_packages_importer/src/index.js