All files / components/Validation Validation.jsx

100% Statements 6/6
100% Branches 7/7
100% Functions 0/0
100% Lines 6/6
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91            134x   134x                   134x                                                                         12x   12x         12x                                                        
import React from 'react';
import PropTypes from 'prop-types';
import { lucidClassNames } from '../../util/style-helpers';
import { createClass, getFirst, omitProps } from '../../util/component-types';
import _ from 'lodash';
 
const cx = lucidClassNames.bind('&-Validation');
 
const { any } = PropTypes;
 
/**
 *
 * {"categories": ["helpers"]}
 *
 * Validation is a wrapper component that's meant to be used by other
 * components. Wrap your form components in it and style them accordingly if
 * there's an error.
 */
const Validation = createClass({
	displayName: 'Validation',
 
	components: {
		/**
		 * Content that will be displayed as an error message.
		 */
		Error: createClass({
			displayName: 'Validation.Error',
			propName: 'Error',
		}),
	},
 
	propTypes: {
		/**
		 * In most cases this will be a string, but it also accepts any valid React
		 * element. If this is a falsey value, then no error message will be
		 * displayed.
		 *
		 * If this is the literal `true`, it will add the `-is-error` class to the
		 * wrapper div, but not render the `-error-content` `div`.
		 */
		Error: any,
 
		/**
		 * Classes that are appended to the component defaults. This prop is run
		 * through the `classnames` library.
		 */
		className: any,
 
		/**
		 * Any valid React children.
		 */
		children: any.isRequired,
	},
 
	render() {
		const { className, children, ...passThroughs } = this.props;
 
		const errorChildProps = _.get(
			getFirst(this.props, Validation.Error),
			'props'
		);
 
		return (
			<div
				{...omitProps(passThroughs, Validation)}
				className={cx(
					'&',
					{
						'&-is-error': errorChildProps && errorChildProps.children,
					},
					className
				)}
			>
				{children}
				{errorChildProps &&
					errorChildProps.children &&
					errorChildProps.children !== true
					? <div
							{...omitProps(errorChildProps, Validation.Error)}
							className={cx('&-error-content', errorChildProps.className)}
						>
							{errorChildProps.children}
						</div>
					: null}
			</div>
		);
	},
});
 
export default Validation;