import React from 'react'; import SilverStripeComponent from 'silverstripe-component'; class FormActionComponent extends SilverStripeComponent { constructor(props) { super(props); this.handleClick = this.handleClick.bind(this); } render() { const props = { type: this.props.type, className: this.getButtonClasses(), disabled: this.props.disabled, }; if (typeof this.props.id !== 'undefined') { props.id = this.props.id; } return ( ); } /** * Returns the necessary button classes based on the given props * * @returns string */ getButtonClasses() { const buttonClasses = ['btn']; // Add 'type' class buttonClasses.push(`btn-${this.props.style}`); // If there is no text if (typeof this.props.label === 'undefined') { buttonClasses.push('no-text'); } // Add icon class if (typeof this.props.icon !== 'undefined') { buttonClasses.push(`font-icon-${this.props.icon}`); } // Add loading class if (this.props.loading === true) { buttonClasses.push('btn--loading'); } // Add disabled class if (this.props.disabled === true) { buttonClasses.push('disabled'); } if (typeof this.props.extraClass !== 'undefined') { buttonClasses.push(this.props.extraClass); } return buttonClasses.join(' '); } /** * Returns markup for the loading icon * * @returns object|null */ getLoadingIcon() { if (this.props.loading) { return (
); } return null; } /** * Event handler triggered when a user clicks the button. * * @param object event * @returns null */ handleClick(event) { this.props.handleClick(event); } } FormActionComponent.propTypes = { id: React.PropTypes.string, handleClick: React.PropTypes.func.isRequired, label: React.PropTypes.string, type: React.PropTypes.string, loading: React.PropTypes.bool, icon: React.PropTypes.string, disabled: React.PropTypes.bool, style: React.PropTypes.string, extraClass: React.PropTypes.string, }; FormActionComponent.defaultProps = { type: 'button', style: 'secondary', disabled: false, }; export default FormActionComponent;