79f7161ae52eccdb270260227eb8c1dea571b4d2
[aai/sparky-fe.git] / src / generic-components / graph / Node.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
28 class Node extends Component {
29                 
30                 static propTypes = {
31                                 x: React.PropTypes.number,
32                                 y: React.PropTypes.number,
33                                 nodeClass: React.PropTypes.string,
34                                 visualElements: React.PropTypes.array,
35                                 meta: React.PropTypes.object
36                 };
37                 
38                 static defaultProps = {
39                                 x: 0,
40                                 y: 0,
41                                 nodeClass: '',
42                                 visualElements: [],
43                                 meta: {}
44                 };
45                 
46                 render() {
47                                 let {x, y, nodeClass, visualElements} = this.props;
48                                 let translate = `translate(${x}, ${y})`;
49                                 
50                                 return (
51                                                 <g className={nodeClass} transform={translate}>
52                                                                 {visualElements}
53                                                 </g>
54                                 );
55                 }
56 }
57
58 export default Node;