7a3781cfdd9b7f137adc4ba4637c11d09bfb58b7
[aai/sparky-fe.git] / src / generic-components / graph / SVGShape.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 import React, {Component} from 'react';
27 import NodeVisualElementConstants from './NodeVisualElementConstants';
28
29 class SVGShape extends Component {
30                 
31                 static propTypes = {
32                                 shapeType: React.PropTypes.string.isRequired,
33                                 shapeAttributes: React.PropTypes.object.isRequired,
34                                 shapeClass: React.PropTypes.object.isRequired,
35                                 textValue: React.PropTypes.string
36                 };
37                 
38                 static defaultProps = {
39                                 shapeType: '',
40                                 shapeAttributes: {},
41                                 shapeClass: {},
42                                 textValue: ''
43                 };
44                 
45                 render() {
46                                 let {shapeType, shapeAttributes, shapeClass, textValue} = this.props;
47                                 
48                                 switch (shapeType) {
49                                                 case NodeVisualElementConstants.SVG_CIRCLE:
50                                                                 return <circle {...shapeAttributes} className={shapeClass}/>;
51                                                 
52                                                 case NodeVisualElementConstants.SVG_LINELINE:
53                                                                 return <line {...shapeAttributes} className={shapeClass}/>;
54                                                 
55                                                 case NodeVisualElementConstants.TEXT:
56                                                                 return <text {...shapeAttributes}
57                                                                                 className={shapeClass}>{textValue}</text>;
58                                                 
59                                                 default:
60                                                                 return undefined;
61                                 }
62                 }
63 }
64
65 export default SVGShape;