123456789101112131415161718192021222324252627282930313233343536 |
- var nodes = require('../nodes')
- , hsla = require('./hsla')
- , component = require('./component');
- /**
- * Return the saturation component of the given `color`,
- * or set the saturation component to the optional second `value` argument.
- *
- * Examples:
- *
- * saturation(#00c)
- * // => 100%
- *
- * saturation(#00c, 50%)
- * // => #339
- *
- * @param {RGBA|HSLA} color
- * @param {Unit} [value]
- * @return {Unit|RGBA}
- * @api public
- */
- function saturation(color, value){
- if (value) {
- var hslaColor = color.hsla;
- return hsla(
- new nodes.Unit(hslaColor.h),
- value,
- new nodes.Unit(hslaColor.l),
- new nodes.Unit(hslaColor.a)
- )
- }
- return component(color, new nodes.String('saturation'));
- }
- saturation.params = ['color', 'value'];
- module.exports = saturation;
|