293 lines
19 KiB
JavaScript
293 lines
19 KiB
JavaScript
|
'use strict';
|
|||
|
|
|||
|
exports.__esModule = true;
|
|||
|
|
|||
|
var _declaration = require('./declaration');
|
|||
|
|
|||
|
var _declaration2 = _interopRequireDefault(_declaration);
|
|||
|
|
|||
|
var _processor = require('./processor');
|
|||
|
|
|||
|
var _processor2 = _interopRequireDefault(_processor);
|
|||
|
|
|||
|
var _stringify = require('./stringify');
|
|||
|
|
|||
|
var _stringify2 = _interopRequireDefault(_stringify);
|
|||
|
|
|||
|
var _comment = require('./comment');
|
|||
|
|
|||
|
var _comment2 = _interopRequireDefault(_comment);
|
|||
|
|
|||
|
var _atRule = require('./at-rule');
|
|||
|
|
|||
|
var _atRule2 = _interopRequireDefault(_atRule);
|
|||
|
|
|||
|
var _vendor = require('./vendor');
|
|||
|
|
|||
|
var _vendor2 = _interopRequireDefault(_vendor);
|
|||
|
|
|||
|
var _parse = require('./parse');
|
|||
|
|
|||
|
var _parse2 = _interopRequireDefault(_parse);
|
|||
|
|
|||
|
var _list = require('./list');
|
|||
|
|
|||
|
var _list2 = _interopRequireDefault(_list);
|
|||
|
|
|||
|
var _rule = require('./rule');
|
|||
|
|
|||
|
var _rule2 = _interopRequireDefault(_rule);
|
|||
|
|
|||
|
var _root = require('./root');
|
|||
|
|
|||
|
var _root2 = _interopRequireDefault(_root);
|
|||
|
|
|||
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|||
|
|
|||
|
/**
|
|||
|
* Create a new {@link Processor} instance that will apply `plugins`
|
|||
|
* as CSS processors.
|
|||
|
*
|
|||
|
* @param {Array.<Plugin|pluginFunction>|Processor} plugins - PostCSS
|
|||
|
* plugins. See {@link Processor#use} for plugin format.
|
|||
|
*
|
|||
|
* @return {Processor} Processor to process multiple CSS
|
|||
|
*
|
|||
|
* @example
|
|||
|
* import postcss from 'postcss';
|
|||
|
*
|
|||
|
* postcss(plugins).process(css, { from, to }).then(result => {
|
|||
|
* console.log(result.css);
|
|||
|
* });
|
|||
|
*
|
|||
|
* @namespace postcss
|
|||
|
*/
|
|||
|
function postcss() {
|
|||
|
for (var _len = arguments.length, plugins = Array(_len), _key = 0; _key < _len; _key++) {
|
|||
|
plugins[_key] = arguments[_key];
|
|||
|
}
|
|||
|
|
|||
|
if (plugins.length === 1 && Array.isArray(plugins[0])) {
|
|||
|
plugins = plugins[0];
|
|||
|
}
|
|||
|
return new _processor2.default(plugins);
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Creates a PostCSS plugin with a standard API.
|
|||
|
*
|
|||
|
* The newly-wrapped function will provide both the name and PostCSS
|
|||
|
* version of the plugin.
|
|||
|
*
|
|||
|
* ```js
|
|||
|
* const processor = postcss([replace]);
|
|||
|
* processor.plugins[0].postcssPlugin //=> 'postcss-replace'
|
|||
|
* processor.plugins[0].postcssVersion //=> '5.1.0'
|
|||
|
* ```
|
|||
|
*
|
|||
|
* The plugin function receives 2 arguments: {@link Root}
|
|||
|
* and {@link Result} instance. The function should mutate the provided
|
|||
|
* `Root` node. Alternatively, you can create a new `Root` node
|
|||
|
* and override the `result.root` property.
|
|||
|
*
|
|||
|
* ```js
|
|||
|
* const cleaner = postcss.plugin('postcss-cleaner', () => {
|
|||
|
* return (root, result) => {
|
|||
|
* result.root = postcss.root();
|
|||
|
* };
|
|||
|
* });
|
|||
|
* ```
|
|||
|
*
|
|||
|
* As a convenience, plugins also expose a `process` method so that you can use
|
|||
|
* them as standalone tools.
|
|||
|
*
|
|||
|
* ```js
|
|||
|
* cleaner.process(css, processOpts, pluginOpts);
|
|||
|
* // This is equivalent to:
|
|||
|
* postcss([ cleaner(pluginOpts) ]).process(css, processOpts);
|
|||
|
* ```
|
|||
|
*
|
|||
|
* Asynchronous plugins should return a `Promise` instance.
|
|||
|
*
|
|||
|
* ```js
|
|||
|
* postcss.plugin('postcss-import', () => {
|
|||
|
* return (root, result) => {
|
|||
|
* return new Promise( (resolve, reject) => {
|
|||
|
* fs.readFile('base.css', (base) => {
|
|||
|
* root.prepend(base);
|
|||
|
* resolve();
|
|||
|
* });
|
|||
|
* });
|
|||
|
* };
|
|||
|
* });
|
|||
|
* ```
|
|||
|
*
|
|||
|
* Add warnings using the {@link Node#warn} method.
|
|||
|
* Send data to other plugins using the {@link Result#messages} array.
|
|||
|
*
|
|||
|
* ```js
|
|||
|
* postcss.plugin('postcss-caniuse-test', () => {
|
|||
|
* return (root, result) => {
|
|||
|
* root.walkDecls(decl => {
|
|||
|
* if ( !caniuse.support(decl.prop) ) {
|
|||
|
* decl.warn(result, 'Some browsers do not support ' + decl.prop);
|
|||
|
* }
|
|||
|
* });
|
|||
|
* };
|
|||
|
* });
|
|||
|
* ```
|
|||
|
*
|
|||
|
* @param {string} name - PostCSS plugin name. Same as in `name`
|
|||
|
* property in `package.json`. It will be saved
|
|||
|
* in `plugin.postcssPlugin` property.
|
|||
|
* @param {function} initializer - will receive plugin options
|
|||
|
* and should return {@link pluginFunction}
|
|||
|
*
|
|||
|
* @return {Plugin} PostCSS plugin
|
|||
|
*/
|
|||
|
postcss.plugin = function plugin(name, initializer) {
|
|||
|
var creator = function creator() {
|
|||
|
var transformer = initializer.apply(undefined, arguments);
|
|||
|
transformer.postcssPlugin = name;
|
|||
|
transformer.postcssVersion = new _processor2.default().version;
|
|||
|
return transformer;
|
|||
|
};
|
|||
|
|
|||
|
var cache = void 0;
|
|||
|
Object.defineProperty(creator, 'postcss', {
|
|||
|
get: function get() {
|
|||
|
if (!cache) cache = creator();
|
|||
|
return cache;
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
creator.process = function (css, processOpts, pluginOpts) {
|
|||
|
return postcss([creator(pluginOpts)]).process(css, processOpts);
|
|||
|
};
|
|||
|
|
|||
|
return creator;
|
|||
|
};
|
|||
|
|
|||
|
/**
|
|||
|
* Default function to convert a node tree into a CSS string.
|
|||
|
*
|
|||
|
* @param {Node} node - start node for stringifing. Usually {@link Root}.
|
|||
|
* @param {builder} builder - function to concatenate CSS from node’s parts
|
|||
|
* or generate string and source map
|
|||
|
*
|
|||
|
* @return {void}
|
|||
|
*
|
|||
|
* @function
|
|||
|
*/
|
|||
|
postcss.stringify = _stringify2.default;
|
|||
|
|
|||
|
/**
|
|||
|
* Parses source css and returns a new {@link Root} node,
|
|||
|
* which contains the source CSS nodes.
|
|||
|
*
|
|||
|
* @param {string|toString} css - string with input CSS or any object
|
|||
|
* with toString() method, like a Buffer
|
|||
|
* @param {processOptions} [opts] - options with only `from` and `map` keys
|
|||
|
*
|
|||
|
* @return {Root} PostCSS AST
|
|||
|
*
|
|||
|
* @example
|
|||
|
* // Simple CSS concatenation with source map support
|
|||
|
* const root1 = postcss.parse(css1, { from: file1 });
|
|||
|
* const root2 = postcss.parse(css2, { from: file2 });
|
|||
|
* root1.append(root2).toResult().css;
|
|||
|
*
|
|||
|
* @function
|
|||
|
*/
|
|||
|
postcss.parse = _parse2.default;
|
|||
|
|
|||
|
/**
|
|||
|
* @member {vendor} - Contains the {@link vendor} module.
|
|||
|
*
|
|||
|
* @example
|
|||
|
* postcss.vendor.unprefixed('-moz-tab') //=> ['tab']
|
|||
|
*/
|
|||
|
postcss.vendor = _vendor2.default;
|
|||
|
|
|||
|
/**
|
|||
|
* @member {list} - Contains the {@link list} module.
|
|||
|
*
|
|||
|
* @example
|
|||
|
* postcss.list.space('5px calc(10% + 5px)') //=> ['5px', 'calc(10% + 5px)']
|
|||
|
*/
|
|||
|
postcss.list = _list2.default;
|
|||
|
|
|||
|
/**
|
|||
|
* Creates a new {@link Comment} node.
|
|||
|
*
|
|||
|
* @param {object} [defaults] - properties for the new node.
|
|||
|
*
|
|||
|
* @return {Comment} new Comment node
|
|||
|
*
|
|||
|
* @example
|
|||
|
* postcss.comment({ text: 'test' })
|
|||
|
*/
|
|||
|
postcss.comment = function (defaults) {
|
|||
|
return new _comment2.default(defaults);
|
|||
|
};
|
|||
|
|
|||
|
/**
|
|||
|
* Creates a new {@link AtRule} node.
|
|||
|
*
|
|||
|
* @param {object} [defaults] - properties for the new node.
|
|||
|
*
|
|||
|
* @return {AtRule} new AtRule node
|
|||
|
*
|
|||
|
* @example
|
|||
|
* postcss.atRule({ name: 'charset' }).toString() //=> "@charset"
|
|||
|
*/
|
|||
|
postcss.atRule = function (defaults) {
|
|||
|
return new _atRule2.default(defaults);
|
|||
|
};
|
|||
|
|
|||
|
/**
|
|||
|
* Creates a new {@link Declaration} node.
|
|||
|
*
|
|||
|
* @param {object} [defaults] - properties for the new node.
|
|||
|
*
|
|||
|
* @return {Declaration} new Declaration node
|
|||
|
*
|
|||
|
* @example
|
|||
|
* postcss.decl({ prop: 'color', value: 'red' }).toString() //=> "color: red"
|
|||
|
*/
|
|||
|
postcss.decl = function (defaults) {
|
|||
|
return new _declaration2.default(defaults);
|
|||
|
};
|
|||
|
|
|||
|
/**
|
|||
|
* Creates a new {@link Rule} node.
|
|||
|
*
|
|||
|
* @param {object} [defaults] - properties for the new node.
|
|||
|
*
|
|||
|
* @return {Rule} new Rule node
|
|||
|
*
|
|||
|
* @example
|
|||
|
* postcss.rule({ selector: 'a' }).toString() //=> "a {\n}"
|
|||
|
*/
|
|||
|
postcss.rule = function (defaults) {
|
|||
|
return new _rule2.default(defaults);
|
|||
|
};
|
|||
|
|
|||
|
/**
|
|||
|
* Creates a new {@link Root} node.
|
|||
|
*
|
|||
|
* @param {object} [defaults] - properties for the new node.
|
|||
|
*
|
|||
|
* @return {Root} new Root node
|
|||
|
*
|
|||
|
* @example
|
|||
|
* postcss.root({ after: '\n' }).toString() //=> "\n"
|
|||
|
*/
|
|||
|
postcss.root = function (defaults) {
|
|||
|
return new _root2.default(defaults);
|
|||
|
};
|
|||
|
|
|||
|
exports.default = postcss;
|
|||
|
module.exports = exports['default'];
|
|||
|
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInBvc3Rjc3MuZXM2Il0sIm5hbWVzIjpbInBvc3Rjc3MiLCJwbHVnaW5zIiwibGVuZ3RoIiwiQXJyYXkiLCJpc0FycmF5IiwiUHJvY2Vzc29yIiwicGx1Z2luIiwibmFtZSIsImluaXRpYWxpemVyIiwiY3JlYXRvciIsInRyYW5zZm9ybWVyIiwicG9zdGNzc1BsdWdpbiIsInBvc3Rjc3NWZXJzaW9uIiwidmVyc2lvbiIsImNhY2hlIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXQiLCJwcm9jZXNzIiwiY3NzIiwicHJvY2Vzc09wdHMiLCJwbHVnaW5PcHRzIiwic3RyaW5naWZ5IiwicGFyc2UiLCJ2ZW5kb3IiLCJsaXN0IiwiY29tbWVudCIsIkNvbW1lbnQiLCJkZWZhdWx0cyIsImF0UnVsZSIsIkF0UnVsZSIsImRlY2wiLCJEZWNsYXJhdGlvbiIsInJ1bGUiLCJSdWxlIiwicm9vdCIsIlJvb3QiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7OztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7Ozs7O0FBRUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQWtCQSxTQUFTQSxPQUFULEdBQTZCO0FBQUEsb0NBQVRDLE9BQVM7QUFBVEEsV0FBUztBQUFBOztBQUN6QixNQUFLQSxRQUFRQyxNQUFSLEtBQW1CLENBQW5CLElBQXdCQyxNQUFNQyxPQUFOLENBQWNILFFBQVEsQ0FBUixDQUFkLENBQTdCLEVBQXlEO0FBQ3JEQSxjQUFVQSxRQUFRLENBQVIsQ0FBVjtBQUNIO0FBQ0QsU0FBTyxJQUFJSSxtQkFBSixDQUFjSixPQUFkLENBQVA7QUFDSDs7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBd0VBRCxRQUFRTSxNQUFSLEdBQWlCLFNBQVNBLE1BQVQsQ0FBZ0JDLElBQWhCLEVBQXNCQyxXQUF0QixFQUFtQztBQUNoRCxNQUFJQyxVQUFVLFNBQVZBLE9BQVUsR0FBbUI7QUFDN0IsUUFBSUMsY0FBY0YsdUNBQWxCO0FBQ0FFLGdCQUFZQyxhQUFaLEdBQTZCSixJQUE3QjtBQUNBRyxnQkFBWUUsY0FBWixHQUE4QixJQUFJUCxtQkFBSixFQUFELENBQWtCUSxPQUEvQztBQUNBLFdBQU9ILFdBQVA7QUFDSCxHQUxEOztBQU9BLE1BQUlJLGNBQUo7QUFDQUMsU0FBT0MsY0FBUCxDQUFzQlAsT0FBdEIsRUFBK0IsU0FBL0IsRUFBMEM7QUFDdENRLE9BRHNDLGlCQUNoQztBQUNGLFVBQUssQ0FBQ0gsS0FBTixFQUFjQSxRQUFRTCxTQUFSO0FBQ2QsYUFBT0ssS0FBUDtBQUNIO0FBSnFDLEdBQTFDOztBQU9BTCxVQUFRUyxPQUFSLEdBQWtCLFVBQVVDLEdBQVYsRUFBZUMsV0FBZixFQUE0QkMsVUFBNUIsRUFBd0M7QUFDdEQsV0FBT3JCLFFBQVEsQ0FBRVMsUUFBUVksVUFBUixDQUFGLENBQVIsRUFBaUNILE9BQWpDLENBQXlDQyxHQUF6QyxFQUE4Q0MsV0FBOUMsQ0FBUDtBQUNILEdBRkQ7O0FBSUEsU0FBT1gsT0FBUDtBQUNILENBckJEOztBQXVCQTs7Ozs7Ozs7Ozs7QUFXQVQsUUFBUXNCLFNBQVIsR0FBb0JBLG1CQUFwQjs7QUFFQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBa0JBdEIsUUFBUXVCLEtBQVIsR0FBZ0JBLGVBQWhCOztBQUVBOzs7Ozs7QUFNQXZCLFFBQVF3QixNQUFSLEdBQWlCQSxnQkFBakI7O0FBRUE7Ozs7OztBQU1BeEIsUUFBUXlCLElBQVIsR0FBZUEsY0FBZjs7QUFFQTs7Ozs7Ozs7OztBQVVBekIsUUFBUTBCLE9BQVIsR0FBa0I7QUFBQSxTQUFZLElBQUlDLGlCQUFKLENBQVlDLFFBQVosQ0FBWjtBQUFBLENBQWxCOztBQUVBOzs7Ozs7Ozs7O0FBVUE1QixRQUFRNkIsTUFBUixHQUFpQjtBQUFBLFNBQVksSUFBSUMsZ0JBQUosQ0FBV0YsUUFBWCxDQUFaO0FBQUEsQ0FBakI7O0FBRUE7Ozs7Ozs7Ozs7QUFVQTVCLFFBQVErQixJQUFSLEdBQWU7QUFBQSxTQUFZLElBQUlDLHFCQUFKLENBQWdCSixRQUFoQixDQUFaO0FBQUEsQ0FBZjs7QUFFQTs7Ozs7Ozs7OztBQVVBNUIsUUFBUWlDLElBQVIsR0FBZTtBQUFBLFNBQVksSUFBSUMsY0FBSixDQUFTTixRQUFULENBQVo7QUFBQSxDQUFmOztBQUVBOzs7Ozs7Ozs7O0FBVUE1QixRQUFRbUMsSUFBUixHQUFlO0FBQUEsU0FBWSxJQUFJQyxjQUFKLENBQVNSLFFBQVQsQ0FBWjtBQUFBLENBQWY7O2tCQUVlNUIsTyIsImZpbGUiOiJwb3N0Y3NzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IERlY2xhcmF0aW9uIGZyb20gJy4vZGVjbGFyYXRpb24nO1xuaW1wb3J0IFByb2Nlc3NvciAgIGZyb20gJy4vcHJvY2Vzc29yJztcbmltcG9ydCBzdHJpbmdpZnkgICBmcm9tICcuL3N0cmluZ2lmeSc7XG5pbXBvcnQgQ29tbWVudCAgICAgZnJvbSAnLi9jb21tZW50JztcbmltcG9ydCBBdFJ1bGUgICAgICBmcm9tICcuL2F0LXJ1bGUnO1xuaW1wb3J0IHZlbmRvciAgICAgIGZyb20gJy4vdmVuZG9yJztcbmltcG9ydCBwYXJzZSAgICAgICBmcm9tICcuL3BhcnNlJztcbmltcG9ydCBsaXN0ICAgICAgICBmcm9tICcuL2xpc3QnO1xuaW1wb3J0IFJ1bGUgICAgICAgIGZyb20gJy4vcnVsZSc7XG5pbXBvcnQgUm9vdCAgICAgICAgZnJvbSAnLi9yb290JztcblxuLyoqXG4gKiBDcmVhdGUgYSBuZXcge0BsaW5rIFByb2Nlc3Nvcn0gaW5zdGFuY2UgdGhhdCB3aWxsIGFwcGx5IGBwbHVnaW5zYFxuICogYXMgQ1NTIHByb2Nlc3NvcnMuXG4gKlxuICogQHBhcmFtIHtBcnJheS48UGx1Z2lufHBsdWdpbkZ1bmN0aW9uPnxQcm9jZXNzb3J9IHBsdWdpbnMgLSBQb3N0Q1NTXG4gKiAgICAgICAgcGx1Z2lucy4gU2VlIHtAbGluayBQcm9jZXNzb3IjdXNlfSBmb3IgcGx1Z2luIGZvcm1hdC5cbiAqXG4gKiBAcmV0dXJuIHtQcm9jZXNzb3J9IFByb2Nlc3NvciB0byBwcm9jZXNzIG11bHRpcGxlIENTU1xuICpcbiAqIEBleGFtcGxlXG4gKiBpbXBvcnQgcG9zdGNzcyBmcm9tICdwb3N0Y3NzJztcbiAqXG4gKiBwb3N0Y3NzKHBsdWdpbnMpLnByb2Nlc3MoY3NzLCB7IGZyb20sIHRvIH0pLnRoZW4ocmVzdWx0ID0+IHtcbiAqICAgY29uc29sZS5sb2cocmVzdWx0LmNzcyk7XG4gKiB9KTtcbiAqXG4gKiBAbmFtZXNwYWNlIHBvc3Rjc3NcbiAqL1xuZnVuY3Rpb24gcG9zdGNzcyguLi5wbHVnaW5zKSB7XG4gICAgaWYgKCBwbHVnaW5zLmxl
|