blob: 64b35d99bc5b895dffc8da31286ba416c076ea9d [file] [log] [blame]
xuegao5fe750c2019-08-06 13:03:53 +02001/*-
2 * ============LICENSE_START=======================================================
3 * ONAP CLAMP
4 * ================================================================================
5 * Copyright (C) 2019 AT&T Intellectual Property. All rights
6 * reserved.
7 * ================================================================================
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
11 *
12 * http://www.apache.org/licenses/LICENSE-2.0
13 *
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
19 * ============LICENSE_END============================================
20 * ===================================================================
21 *
22 */
23import React from 'react';
24import LoopActionService from '../../api/LoopActionService';
xuegao0efeb6b2019-10-07 14:36:34 +020025import Spinner from 'react-bootstrap/Spinner';
xuegao5fe750c2019-08-06 13:03:53 +020026import styled from 'styled-components';
27
28const StyledSpinnerDiv = styled.div`
29 justify-content: center !important;
30 display: flex !important;
31`;
32
33export default class RefreshStatus extends React.Component {
34 state = {
35 loopName: this.props.loopCache.getLoopName()
36 };
37
38 componentWillReceiveProps(newProps) {
39 this.setState({
40 loopName: newProps.loopCache.getLoopName()
41 });
42 }
43
44 componentDidMount() {
xuegao5fe750c2019-08-06 13:03:53 +020045 // refresh status and update loop logs
46 LoopActionService.refreshStatus(this.state.loopName).then(data => {
xuegao0efeb6b2019-10-07 14:36:34 +020047 this.props.showAlert("Status successfully refreshed");
xuegao5fe750c2019-08-06 13:03:53 +020048 this.props.updateLoopFunction(data);
49 this.props.history.push('/');
50 })
51 .catch(error => {
xuegao0efeb6b2019-10-07 14:36:34 +020052 this.props.showAlert("Status refreshing failed");
xuegao5fe750c2019-08-06 13:03:53 +020053 this.props.history.push('/');
54 });
55 }
56
57 render() {
58 return (
59 <StyledSpinnerDiv>
60 <Spinner animation="border" role="status">
61 </Spinner>
62 </StyledSpinnerDiv>
63 );
64 }
65}