Initial coomit for AAI-UI(sparky-fe)
[aai/sparky-fe.git] / src / generic-components / input / validation / ValidationButtons.jsx
1 /*
2  * ============LICENSE_START===================================================
3  * SPARKY (AAI UI service)
4  * ============================================================================
5  * Copyright © 2017 AT&T Intellectual Property.
6  * Copyright © 2017 Amdocs
7  * All rights reserved.
8  * ============================================================================
9  * Licensed under the Apache License, Version 2.0 (the "License");
10  * you may not use this file except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *      http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  * ============LICENSE_END=====================================================
21  *
22  * ECOMP and OpenECOMP are trademarks
23  * and service marks of AT&T Intellectual Property.
24  */
25
26 /**
27         * Holds the buttons for save/reset for forms.
28         * Used by the ValidationForm that changes the state of the buttons according
29         * to its own state.
30         *
31         * properties:
32         * labledButtons - whether or not to use labeled buttons or icons only
33         */
34 import React from 'react';
35 import i18n from 'utils/i18n/i18n.js';
36 import Button from 'react-bootstrap/lib/Button.js';
37 import FontAwesome from 'react-fontawesome';
38
39 class ValidationButtons extends React.Component {
40                 
41                 static propTypes = {
42                                 labledButtons: React.PropTypes.bool.isRequired,
43                                 isReadOnlyMode: React.PropTypes.bool
44                 };
45                 
46                 state = {
47                                 isValid: this.props.formValid
48                 };
49                 
50                 render() {
51                                 var submitBtn = this.props.labledButtons ? i18n('Save') :
52                                                 <FontAwesome className='check' name='check'/>;
53                                 var closeBtn = this.props.labledButtons ? i18n('Cancel') :
54                                                <FontAwesome className='close' name='close'/>;
55                                 return (
56                                                 <div className='validation-buttons'>
57                                                                 {!this.props.isReadOnlyMode ?
58                                                                  <div>
59                                                                                  <Button bsStyle='primary' ref='submitbutton' type='submit'
60                                                                                          disabled={!this.state.isValid}>{submitBtn}</Button>
61                                                                                  <Button type='reset'>{closeBtn}</Button>
62                                                                  </div>
63                                                                                 : <Button type='reset'>{i18n('Close')}</Button>
64                                                                 }
65                                                 </div>
66                                 );
67                 }
68 }
69 export default ValidationButtons;