UNPKG

jss-plugin-compose

Version:

JSS plugin for classes composition

79 lines (57 loc) 2.14 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var warning = require('tiny-warning'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var warning__default = /*#__PURE__*/_interopDefaultLegacy(warning); /** * Set selector. * * @param original rule * @param className class string * @return flag indicating function was successfull or not */ function registerClass(rule, className) { // Skip falsy values if (!className) return true; // Support array of class names `{composes: ['foo', 'bar']}` if (Array.isArray(className)) { for (var index = 0; index < className.length; index++) { var isSetted = registerClass(rule, className[index]); if (!isSetted) return false; } return true; } // Support space separated class names `{composes: 'foo bar'}` if (className.indexOf(' ') > -1) { return registerClass(rule, className.split(' ')); } var parent = rule.options.parent; // It is a ref to a local rule. if (className[0] === '$') { var refRule = parent.getRule(className.substr(1)); if (!refRule) { process.env.NODE_ENV !== "production" ? warning__default['default'](false, "[JSS] Referenced rule is not defined. \n" + rule.toString()) : void 0; return false; } if (refRule === rule) { process.env.NODE_ENV !== "production" ? warning__default['default'](false, "[JSS] Cyclic composition detected. \n" + rule.toString()) : void 0; return false; } parent.classes[rule.key] += " " + parent.classes[refRule.key]; return true; } parent.classes[rule.key] += " " + className; return true; } /** * Convert compose property to additional class, remove property from original styles. */ function jssCompose() { function onProcessStyle(style, rule) { if (!('composes' in style)) return style; registerClass(rule, style.composes); // Remove composes property to prevent infinite loop. delete style.composes; return style; } return { onProcessStyle: onProcessStyle }; } exports.default = jssCompose;