| /*! |
| * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved. |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express |
| * or implied. See the License for the specific language governing |
| * permissions and limitations under the License. |
| */ |
| /** |
| * Holds the buttons for save/reset for forms. |
| * Used by the ValidationForm that changes the state of the buttons according to its own state. |
| * |
| * properties: |
| * labledButtons - whether or not to use labeled buttons or icons only |
| */ |
| import React from 'react'; |
| import PropTypes from 'prop-types'; |
| import i18n from 'nfvo-utils/i18n/i18n.js'; |
| import Button from 'sdc-ui/lib/react/Button.js'; |
| import SVGIcon from 'sdc-ui/lib/react/SVGIcon.js'; |
| |
| class ValidationButtons extends React.Component { |
| static propTypes = { |
| labledButtons: PropTypes.bool.isRequired, |
| isReadOnlyMode: PropTypes.bool, |
| submitButtonText: PropTypes.string, |
| cancelButtonText: PropTypes.string |
| }; |
| |
| state = { |
| isValid: this.props.formValid |
| }; |
| |
| render() { |
| let submitBtn = this.props.labledButtons ? ( |
| this.props.submitButtonText ? ( |
| this.props.submitButtonText |
| ) : ( |
| i18n('Save') |
| ) |
| ) : ( |
| <SVGIcon className="check" name="check" /> |
| ); |
| let closeBtn = this.props.labledButtons ? ( |
| this.props.cancelButtonText ? ( |
| this.props.cancelButtonText |
| ) : ( |
| i18n('Cancel') |
| ) |
| ) : ( |
| <SVGIcon className="close" name="close" /> |
| ); |
| return ( |
| <div className="validation-buttons"> |
| {!this.props.isReadOnlyMode ? ( |
| <div> |
| <Button |
| type="submit" |
| data-test-id="form-submit-button" |
| disabled={!this.state.isValid}> |
| {submitBtn} |
| </Button> |
| <Button |
| btnType="outline" |
| type="reset" |
| data-test-id="form-close-button"> |
| {closeBtn} |
| </Button> |
| </div> |
| ) : ( |
| <Button |
| btnType="outline" |
| type="reset" |
| data-test-id="form-close-button"> |
| {i18n('Close')} |
| </Button> |
| )} |
| </div> |
| ); |
| } |
| } |
| export default ValidationButtons; |