EsifyCSS
data:image/s3,"s3://crabby-images/87ba1/87ba1b4fb8b663fd7639ac183cef7005b8e50253" alt="codecov"
Generates modules from CSS.
Assume you have style.css
below.
data:image/s3,"s3://crabby-images/d9a08/d9a0860050bc9b127d95a8d4033fb9ef93b20e7e" alt="A screen shot of style.css"
Then, run the esifycss
command.
data:image/s3,"s3://crabby-images/6fb8a/6fb8ae6710cfa0abaf1334ea8b51c03942fce7ae" alt="A video of the result"
You'll get style.css.js
(and helper.js
).
data:image/s3,"s3://crabby-images/12113/121139113f2b5e131e3fc301b0d977807d0b7ac4" alt="A screen shot of style.css.js"
You can import the generated script from
It exports className
, id
, and keyframes
that are shortened uniquely.
The uniqueness makes styles modular. This means you don't have to concern about
naming somethings in CSS.
Each string given to addStyle
represents a CSS string.
They are inserted to the document's stylesheet by the helper script.
EsifyCSS consists of a PostCSS plugin and a Runner.
PostCSS plugin
The plugin converts the identifiers in CSS and minifies them.
It outputs the result of minifications using Root.warn().
Runner
A runner process .css
files in your project with PostCSS and output the
results to .css.js
or .css.ts
.
Installation
npm install --save-dev esifycss
Usage
Usage: esifycss [options] <include ...>
Options:
-V, --version output the version number
--helper <path> A path to the helper script.
--config <path> A path to configuration files.
--exclude <path ...> Paths or patterns to be excluded.
--noMangle Keep the original name for debugging.
--watch Watch files and update the modules automatically.
-h, --help output usage information
@import
Syntax
You can use @import
syntax when the style declarations requires names in external files.
Example: Assume you have the following a.css
and b.css
.
.container {...}
.container {...}
The container
class names will be shortened to unique names like
_0
and _1
.
You can import the shortened names with the @import
syntax.
@import './a.css' modA-;
@import './b.css' BBB;
.wrapper>.modA-container {...}
.wrapper>.BBBcontainer {...}
JavaScript API for Runner
import {Session} from 'esifycss';
new Session(options).start()
.then(() => console.log('Done'))
.catch((error) => console.error(error));
Options
export interface ISessionOptions {
include?: string | Array<string>,
exclude?: anymatch.Matcher,
helper?: string,
watch?: boolean,
chokidar?: chokidar.WatchOptions,
postcssPlugins?: Array<postcss.AcceptedPlugin>,
esifycssPluginParameter?: IPluginOptions,
stdout?: stream.Writable,
stderr?: stream.Writable,
}
Source: src/runner/types.ts
JavaScript API for Plugin
const postcss = require('postcss');
const esifycss = require('esifycss');
postcss([
esifycss.plugin({}),
])
.process(css, {from: '/foo/bar.css'})
.then((result) => {
const pluginResult = esifycss.extractPluginResult(result);
console.log(pluginResult);
});
The code is at sample/plugin.js.
You can run it by node sample/plugin.js
after cloning this repository and
running npm run build
.
Options
export interface IPluginOptions {
mangle?: boolean,
identifier?: IIdentifier,
rawPrefix?: string,
mangler?: IPluginMangler,
}
Source: src/postcssPlugin/types.ts
LICENSE
The esifycss project is licensed under the terms of the Apache 2.0 License.