react-base16-styling
Version:
React styling with base16 color scheme support
331 lines (259 loc) • 12 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof3 = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
var _exportNames = {
invertBase16Theme: true,
createStyling: true,
getBase16Theme: true,
invertTheme: true
};
exports.invertTheme = exports.invertBase16Theme = exports.getBase16Theme = exports.createStyling = void 0;
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var base16 = _interopRequireWildcard(require("base16"));
var _color = _interopRequireDefault(require("color"));
var _lodash = _interopRequireDefault(require("lodash.curry"));
var _colorConverters = require("./colorConverters");
var _types = require("./types");
Object.keys(_types).forEach(function (key) {
if (key === "default" || key === "__esModule") return;
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
if (key in exports && exports[key] === _types[key]) return;
Object.defineProperty(exports, key, {
enumerable: true,
get: function get() {
return _types[key];
}
});
});
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
var DEFAULT_BASE16 = base16.default;
var BASE16_KEYS = Object.keys(DEFAULT_BASE16); // we need a correcting factor, so that a dark, but not black background color
// converts to bright enough inversed color
var flip = function flip(x) {
return x < 0.25 ? 1 : x < 0.5 ? 0.9 - x : 1.1 - x;
};
var invertColor = function invertColor(hexString) {
var color = (0, _color.default)(hexString);
var _rgb2yuv = (0, _colorConverters.rgb2yuv)(color.array()),
_rgb2yuv2 = (0, _slicedToArray2.default)(_rgb2yuv, 3),
y = _rgb2yuv2[0],
u = _rgb2yuv2[1],
v = _rgb2yuv2[2];
var flippedYuv = [flip(y), u, v];
var rgb = (0, _colorConverters.yuv2rgb)(flippedYuv);
return _color.default.rgb(rgb).hex();
};
var merger = function merger(styling) {
return function (prevStyling) {
return {
className: [prevStyling.className, styling.className].filter(Boolean).join(' '),
style: _objectSpread(_objectSpread({}, prevStyling.style || {}), styling.style || {})
};
};
};
var mergeStyling = function mergeStyling(customStyling, defaultStyling) {
if (customStyling === undefined) {
return defaultStyling;
}
if (defaultStyling === undefined) {
return customStyling;
}
var customType = (0, _typeof2.default)(customStyling);
var defaultType = (0, _typeof2.default)(defaultStyling);
switch (customType) {
case 'string':
switch (defaultType) {
case 'string':
return [defaultStyling, customStyling].filter(Boolean).join(' ');
case 'object':
return merger({
className: customStyling,
style: defaultStyling
});
case 'function':
return function (styling) {
for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
args[_key - 1] = arguments[_key];
}
return merger({
className: customStyling
})(defaultStyling.apply(void 0, [styling].concat(args)));
};
}
break;
case 'object':
switch (defaultType) {
case 'string':
return merger({
className: defaultStyling,
style: customStyling
});
case 'object':
return _objectSpread(_objectSpread({}, defaultStyling), customStyling);
case 'function':
return function (styling) {
for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
args[_key2 - 1] = arguments[_key2];
}
return merger({
style: customStyling
})(defaultStyling.apply(void 0, [styling].concat(args)));
};
}
break;
case 'function':
switch (defaultType) {
case 'string':
return function (styling) {
for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) {
args[_key3 - 1] = arguments[_key3];
}
return customStyling.apply(void 0, [merger(styling)({
className: defaultStyling
})].concat(args));
};
case 'object':
return function (styling) {
for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) {
args[_key4 - 1] = arguments[_key4];
}
return customStyling.apply(void 0, [merger(styling)({
style: defaultStyling
})].concat(args));
};
case 'function':
return function (styling) {
for (var _len5 = arguments.length, args = new Array(_len5 > 1 ? _len5 - 1 : 0), _key5 = 1; _key5 < _len5; _key5++) {
args[_key5 - 1] = arguments[_key5];
}
return customStyling.apply(void 0, [defaultStyling.apply(void 0, [styling].concat(args))].concat(args));
};
}
}
};
var mergeStylings = function mergeStylings(customStylings, defaultStylings) {
var keys = Object.keys(defaultStylings);
for (var key in customStylings) {
if (keys.indexOf(key) === -1) keys.push(key);
}
return keys.reduce(function (mergedStyling, key) {
return mergedStyling[key] = mergeStyling(customStylings[key], defaultStylings[key]), mergedStyling;
}, {});
};
var getStylingByKeys = function getStylingByKeys(mergedStyling, keys) {
for (var _len6 = arguments.length, args = new Array(_len6 > 2 ? _len6 - 2 : 0), _key6 = 2; _key6 < _len6; _key6++) {
args[_key6 - 2] = arguments[_key6];
}
if (keys === null) {
return mergedStyling;
}
if (!Array.isArray(keys)) {
keys = [keys];
}
var styles = keys.map(function (key) {
return mergedStyling[key];
}).filter(Boolean);
var props = styles.reduce(function (obj, s) {
if (typeof s === 'string') {
obj.className = [obj.className, s].filter(Boolean).join(' ');
} else if ((0, _typeof2.default)(s) === 'object') {
obj.style = _objectSpread(_objectSpread({}, obj.style), s);
} else if (typeof s === 'function') {
obj = _objectSpread(_objectSpread({}, obj), s.apply(void 0, [obj].concat(args)));
}
return obj;
}, {
className: '',
style: {}
});
if (!props.className) {
delete props.className;
}
if (Object.keys(props.style).length === 0) {
delete props.style;
}
return props;
};
var invertBase16Theme = function invertBase16Theme(base16Theme) {
return Object.keys(base16Theme).reduce(function (t, key) {
return t[key] = /^base/.test(key) ? invertColor(base16Theme[key]) : key === 'scheme' ? base16Theme[key] + ':inverted' : base16Theme[key], t;
}, {});
};
exports.invertBase16Theme = invertBase16Theme;
var createStyling = (0, _lodash.default)(function (getStylingFromBase16) {
var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
var themeOrStyling = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var _options$defaultBase = options.defaultBase16,
defaultBase16 = _options$defaultBase === void 0 ? DEFAULT_BASE16 : _options$defaultBase,
_options$base16Themes = options.base16Themes,
base16Themes = _options$base16Themes === void 0 ? null : _options$base16Themes;
var base16Theme = getBase16Theme(themeOrStyling, base16Themes);
if (base16Theme) {
themeOrStyling = _objectSpread(_objectSpread({}, base16Theme), themeOrStyling);
}
var theme = BASE16_KEYS.reduce(function (t, key) {
return t[key] = themeOrStyling[key] || defaultBase16[key], t;
}, {});
var customStyling = Object.keys(themeOrStyling).reduce(function (s, key) {
return BASE16_KEYS.indexOf(key) === -1 ? (s[key] = themeOrStyling[key], s) : s;
}, {});
var defaultStyling = getStylingFromBase16(theme);
var mergedStyling = mergeStylings(customStyling, defaultStyling);
for (var _len7 = arguments.length, args = new Array(_len7 > 3 ? _len7 - 3 : 0), _key7 = 3; _key7 < _len7; _key7++) {
args[_key7 - 3] = arguments[_key7];
}
return (0, _lodash.default)(getStylingByKeys, 2).apply(void 0, [mergedStyling].concat(args));
}, 3);
exports.createStyling = createStyling;
var isStylingConfig = function isStylingConfig(theme) {
return !!theme.extend;
};
var getBase16Theme = function getBase16Theme(theme, base16Themes) {
if (theme && isStylingConfig(theme) && theme.extend) {
theme = theme.extend;
}
if (typeof theme === 'string') {
var _theme$split = theme.split(':'),
_theme$split2 = (0, _slicedToArray2.default)(_theme$split, 2),
_themeName = _theme$split2[0],
modifier = _theme$split2[1];
if (base16Themes) {
theme = base16Themes[_themeName];
} else {
theme = base16[_themeName];
}
if (modifier === 'inverted') {
theme = invertBase16Theme(theme);
}
}
return theme && Object.prototype.hasOwnProperty.call(theme, 'base00') ? theme : undefined;
};
exports.getBase16Theme = getBase16Theme;
var invertTheme = function invertTheme(theme) {
if (typeof theme === 'string') {
return "".concat(theme, ":inverted");
}
if (theme && isStylingConfig(theme) && theme.extend) {
if (typeof theme.extend === 'string') {
return _objectSpread(_objectSpread({}, theme), {}, {
extend: "".concat(theme.extend, ":inverted")
});
}
return _objectSpread(_objectSpread({}, theme), {}, {
extend: invertBase16Theme(theme.extend)
});
}
if (theme) {
return invertBase16Theme(theme);
}
return theme;
};
exports.invertTheme = invertTheme;