PostCSS plugin to rebase, inline or copy on url().
$ npm install postcss-url
// dependencies
var fs = require("fs")
var postcss = require("postcss")
var url = require("postcss-url")
// css to be processed
var css = fs.readFileSync("input.css", "utf8")
// process css
var output = postcss()
.use(url({
url: "rebase" // or "inline" or "copy"
}))
.process(css, {
// "rebase" mode need at least one of those options
// "inline" mode might need `from` option only
// "copy" mode need `from` and `to` option to work
from: "src/stylesheet/index.css",
to: "dist/index.css"
})
.css
Checkout tests for examples.
(default: "rebase"
)
Allow you to fix url()
according to postcss to
and/or from
options (rebase to to
first if available, otherwise from
or process.cwd()
).
Allow you to inline assets using base64 encoding. Can use postcss from
option to find ressources.
Allow you to copy and rebase assets according to postcss to
, assetsPath
and from
options (assetsPath
is relative to the option to
).
Custom transform function. Takes following arguments:
URL
– original urldecl
- related postcss declaration objectfrom
- from postcss optiondirname
– dirname of processing fileto
– from postcss optionoptions
– plugin optionsresult
– postcss result object
And should return the transformed url. You can use this option to adjust urls for CDN.
(default: 14
)
Specify the maximum file size to inline (in kbytes)
A regular expression e.g. /\.svg$/
, a minimatch string e.g. '**/*.svg'
or a custom filter function to determine wether a file should be inlined.
The url fallback method to use if max size is exceeded or url contains a hash. Custom transform functions are supported.
Specify the base path or paths where to search images from. Can be a string for a single path or an array of paths. For example basePath: path.resolve(__dirname, 'src')
or basePath: [path.resolve(__dirname, 'src'), path.resolve(__dirname, 'node_modules')]
.
Example: given that images are located in src/assets
, using basePath: path.resolve(__dirname, 'src')
and background-image: url("assets/my-image.png");
will resolve the image correctly.
Note: this option will have no effect on paths starting with a .
, for example background-image: url("./my-image.png");
or other relative paths.
(default: false
)
If you specify an assetsPath
, the assets files will be copied in that
destination
(default: false
)
If set to true
the copy method is going to rename the path of the files by a hash name
Work on a branch, install dev-dependencies, respect coding style & run tests before submitting a bug fix or a feature.
$ git clone https://github.com/postcss/postcss-url.git
$ git checkout -b patch-1
$ npm install
$ npm test