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          120x       120x                   120x                                                                                 12x   12x   12x                                            
import React from 'react';
import { lucidClassNames } from '../../util/style-helpers';
import { createClass, getFirst, omitProps } from '../../util/component-types';
import _ from 'lodash';
 
const cx = lucidClassNames.bind('&-Validation');
 
const {
	any,
} = React.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;