aboutsummaryrefslogtreecommitdiffstats
path: root/ui-react/src/components/dialogs/Tosca/UploadToscaPolicyModal.js
blob: 1937485b089836989e880000c1578255903ca640 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/*-
 * ============LICENSE_START=======================================================
 * ONAP CLAMP
 * ================================================================================
 * Copyright (C) 2020 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.
 * ============LICENSE_END============================================
 * ===================================================================
 *
 */

import React from 'react'
import Button from 'react-bootstrap/Button';
import Modal from 'react-bootstrap/Modal';
import Form from 'react-bootstrap/Form';
import Row from 'react-bootstrap/Row';
import Col from 'react-bootstrap/Col';
import styled from 'styled-components';
import Alert from 'react-bootstrap/Alert';
import PolicyToscaService from '../../../api/PolicyToscaService';

const ModalStyled = styled(Modal)`
	background-color: transparent;
`
export default class UploadToscaPolicyModal extends React.Component {
	constructor(props, context) {
		super(props, context);

		this.handleCreateFromToscaPolicyModel = this.handleCreateFromToscaPolicyModel.bind(this);
		this.handleClose = this.handleClose.bind(this);
		this.fileSelectedHandler = this.fileSelectedHandler.bind(this);
		this.state = {
				show: true,
				selectedFile: '',
				policyModelTosca: [],
				apiResponseStatus: '',
				apiResponseMessage: '',
				upldBtnClicked: false
			};
		}

		fileSelectedHandler = (event) => {
				if (event.target.files && event.target.files[0]) {
					const scope = this;
  				    let reader = new FileReader();
					this.setState({policyModelTosca: '' });
					reader.onload = function(e) {
					    scope.setState({ policyModelTosca:  reader.result});
					};
					console.log("Filename is", event.target.files[0]);
					reader.readAsText(event.target.files[0]);
				}
				this.setState({selectedFile: event.target.files[0]});
		};

	handleClose() {
		this.setState({ show: false });
		this.props.history.push('/');
	}

	handleCreateFromToscaPolicyModel(e) {
        e.preventDefault();
		if(this.state.policyModelTosca) {
 		PolicyToscaService.createPolicyModelFromToscaModel(this.state.policyModelTosca).then(resp => {
			if(resp.status === 200) {
			this.setState({apiResponseStatus: resp.status, apiResponseMessage: resp.message, upldBtnClicked: true});
		} else {
			this.setState({apiResponseStatus: 500, apiResponseMessage: resp, upldBtnClicked: true});
		}
	});
	} else {
		this.setState({apiResponse: 500, apiResponseMessage: 'Parameters are missing', upldBtnClicked: true});
	}
}

	render() {
		return (
			<ModalStyled size="lg" show={this.state.show} onHide={this.handleClose}>
				<Modal.Header closeButton>
					<Modal.Title>Upload Tosca Model</Modal.Title>
				</Modal.Header>
				<Modal.Body>
					<Form.Group as={Row} controlId="formPlaintextEmail">
						<Col sm="10">
						<input style={{display: 'none'}} type="file" name="file" accept=".yaml" onChange={this.fileSelectedHandler}
							ref={fileInput => this.fileInput = fileInput}/>
						<button onClick={() => this.fileInput.click()}>Pick Tosca File</button>
							<Alert variant="secondary">
								<p>{this.state.selectedFile.name}</p>
							</Alert>
						</Col>
					</Form.Group>
				</Modal.Body>
				<Modal.Footer>
					{!this.state.apiResponseStatus?<Button variant="secondary" type="null" onClick={this.handleClose}>Cancel</Button>:""}
				  {!this.state.apiResponseStatus?<Button disabled={!this.state.selectedFile.name || this.state.upldBtnClicked} variant="primary" type="submit" onClick={this.handleCreateFromToscaPolicyModel.bind(this)}>Create</Button>:""}
					{this.state.apiResponseStatus?<Alert variant={this.state.apiResponseStatus === 200?"success":"danger"}>
							<p>{this.state.apiResponseMessage}</p>
								<Button onClick={this.handleClose} variant={this.state.apiResponseStatus === 200?"outline-success":"danger"}>
									Exit
								</Button>
						</Alert>:""}
				</Modal.Footer>
			</ModalStyled>
		);
	}
}