a8ef717b3686b346d4b83a108ae0e115ad5bab8f
[clamp.git] / ui-react / src / components / dialogs / UserInfo.js
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP CLAMP
4  * ================================================================================
5  * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6  * ================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  * http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END============================================
19  * ===================================================================
20  *
21  */
22
23 import React from 'react'
24 import Button from 'react-bootstrap/Button';
25 import Modal from 'react-bootstrap/Modal';
26 import Form from 'react-bootstrap/Form';
27 import Row from 'react-bootstrap/Row';
28 import Col from 'react-bootstrap/Col';
29 import styled from 'styled-components';
30 import UserService from '../../api/UserService';
31
32 const ModalStyled = styled(Modal)`
33         background-color: transparent;
34 `
35
36 export default class UserInfo extends React.Component {
37
38         constructor(props, context) {
39                 super(props, context);
40
41                 this.handleClose = this.handleClose.bind(this);
42                 this.initialValues = this.initialValues.bind(this);
43                 this.renderReadTemplatePermission = this.renderReadTemplatePermission.bind(this);
44                 this.renderReadModelPermission = this.renderReadModelPermission.bind(this);
45                 this.renderReadToscaPermission = this.renderReadToscaPermission.bind(this);
46                 this.renderUpdateTemplatePermission = this.renderUpdateTemplatePermission.bind(this);
47                 this.renderUpdateModelPermission = this.renderUpdateModelPermission.bind(this);
48                 this.renderUpdateToscaPermission = this.renderUpdateToscaPermission.bind(this);
49                 this.renderUserName = this.renderUserName.bind(this);
50                 this.state = {
51                         show: true,
52                         userInfo: {permissionReadTemplate: true,
53                                                 permissionReadCl: true,
54                                                 permissionReadTosca: true,
55                                                 permissionUpdateCl: true,
56                                                 permissionUpdateTemplate: true,
57                                                 permissionUpdateTosca: true,
58                                                 userName: 'admin',
59                                                 cldsVersion: '1.0.0'
60                                                 }
61                 };
62
63         }
64         initialValues() {
65                 UserService.getUserInfo().then(userInfo => {
66                         this.setState({ userInfo: userInfo })
67                 });
68         }
69         handleClose() {
70                         this.props.history.push('/');
71         }
72         renderReadTemplatePermission() {
73                 if (this.state.userInfo["permissionReadTemplate"]) {
74                         return <Form.Control plaintext readOnly defaultValue="Read Template" />
75                 } else  {
76                         return;
77                 }
78         }
79         renderReadModelPermission() {
80                 if (this.state.userInfo["permissionReadCl"]) {
81                         return <Form.Control plaintext readOnly defaultValue="Read Model" />
82                 } else  {
83                         return;
84                 }
85         }
86         renderReadToscaPermission() {
87                 if (this.state.userInfo["permissionReadTosca"]) {
88                         return <Form.Control plaintext readOnly defaultValue="Read Tosca" />
89                 } else  {
90                         return;
91                 }
92         }
93         renderUpdateTemplatePermission() {
94                 if (this.state.userInfo["permissionUpdateTemplate"]) {
95                         return <Form.Control plaintext readOnly defaultValue="Edit Template" />
96                 } else  {
97                         return;
98                 }
99         }
100         renderUpdateModelPermission() {
101                 if (this.state.userInfo["permissionUpdateCl"]) {
102                         return <Form.Control plaintext readOnly defaultValue="Edit Model" />
103                 } else  {
104                         return;
105                 }
106         }
107         renderUpdateToscaPermission() {
108                 if (this.state.userInfo["permissionUpdateTosca"]) {
109                         return <Form.Control plaintext readOnly defaultValue="Edit Tosca" />
110                 } else  {
111                         return;
112                 }
113         }
114         renderUserName() {
115                 if (this.state.userInfo["userName"]) {
116                         return <Form.Control plaintext readOnly defaultValue={this.state.userInfo["userName"]} />
117                 } else  {
118                         return;
119                 }
120         }
121         renderVersion() {
122                 if (this.state.userInfo["cldsVersion"]) {
123                         return <Form.Control plaintext readOnly defaultValue={this.state.userInfo["cldsVersion"]} />
124                 } else  {
125                         return;
126                 }
127         }
128         render() {
129                 return (
130                         <ModalStyled size="lg"  show={this.state.show} onHide={this.handleClose} onEntered={this.initialValues}>
131                                 <Modal.Header closeButton>
132                                         <Modal.Title>User Info</Modal.Title>
133                                 </Modal.Header>
134                                 <Modal.Body>
135                                         <Form.Group as={Row} controlId="userName">
136                                                 <Form.Label column sm="3">Current User:</Form.Label>
137                                                 <Col>{this.renderUserName()}</Col>
138                                         </Form.Group>
139                                         <Form.Group as={Row} controlId="cldsVersion">
140                                                 <Form.Label column sm="3">CLDS Version:</Form.Label>
141                                                 <Col>{this.renderVersion()}</Col>
142                                         </Form.Group>
143                                         <Form.Group as={Row} controlId="userPermissions">
144                                                 <Form.Label column sm="3">User Permissions:</Form.Label>
145                                                 <Col>
146                                                         {this.renderReadTemplatePermission()}
147                                                         {this.renderReadModelPermission()}
148                                                         {this.renderReadToscaPermission()}
149                                                         {this.renderUpdateTemplatePermission()}
150                                                         {this.renderUpdateModelPermission()}
151                                                         {this.renderUpdateToscaPermission()}
152                                                 </Col>
153                                         </Form.Group>
154                                 </Modal.Body>
155                                 <Modal.Footer>
156                                         <Button variant="secondary" type="null" onClick={this.handleClose}>Cacel</Button>
157                                 </Modal.Footer>
158                         </ModalStyled>
159                 );
160         }
161 }