4 * Copyright 2016 RIFT.IO Inc
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
19 import React from 'react';
20 import LaunchpadCard from './launchpad_card/launchpadCard.jsx';
21 import Loader from 'widgets/loading-indicator/loadingIndicator.jsx';
22 import ScreenLoader from 'widgets/screen-loader/screenLoader.jsx';
23 import MPFilter from './monitoring-params-filter.jsx'
24 import NsCardPanel from './nsCardPanel/nsCardPanel.jsx';
25 import NsListPanel from './nsListPanel/nsListPanel.jsx';
26 import Crouton from 'react-crouton'
27 import AppHeader from 'widgets/header/header.jsx';
28 import Utils from 'utils/utils.js';
29 import './launchpad.scss';
31 import {SkyquakeRBAC, isRBACValid} from 'widgets/skyquake_rbac/skyquakeRBAC.jsx';
32 import ROLES from 'utils/roleConstants.js';
34 const PROJECT_ROLES = ROLES.PROJECT;
36 let ReactCSSTransitionGroup = require('react-addons-css-transition-group');
37 var LaunchpadFleetActions = require('./launchpadFleetActions.js');
38 var LaunchpadFleetStore = require('./launchpadFleetStore.js');
40 export default class LaunchpadApp extends React.Component {
44 this.state = LaunchpadFleetStore.getState();
45 this.state.slideno = 0;
46 this.handleUpdate = this.handleUpdate.bind(this);
50 LaunchpadFleetStore.getCatalog();
51 LaunchpadFleetStore.listen(this.handleUpdate);
53 // Can not put a dispatch here it causes errors
54 // LaunchpadFleetActions.validateReset();
55 setTimeout(function() {
56 LaunchpadFleetStore.openNSRSocket();
59 setTimeout(function() {
60 consoleo.log("launchpad.componentDidMount openNsrListSocket");
61 LaunchpadFleetStore.openNsrListSocket();
73 LaunchpadFleetActions.validateReset()
75 componentWillUnmount() {
76 LaunchpadFleetStore.closeSocket();
77 LaunchpadFleetStore.unlisten(this.handleUpdate);
80 handleOpenNsCard(nsr) {
81 LaunchpadFleetActions.openNSRCard(nsr);
84 handleCloseNsCard(id) {
85 LaunchpadFleetActions.closeNSRCard(id);
88 handleShowHideNsListPanelToggle() {
90 showNsListPanel: !this.state.showNsListPanel
95 return this.state.nsrs;
100 const hasAccess = isRBACValid(this.context.userProfile, [PROJECT_ROLES.LCM_ADMIN]);
101 let mgmtDomainName = window.location.hash.split('/')[2];
103 if(!mgmtDomainName) {
104 mgmtDomainName = 'dashboard';
106 if(mgmtDomainName.toUpperCase() == 'DASHBOARD' || mgmtDomainName.toUpperCase() == 'UNDEFINED') {
109 mgmtDomainName = ' : ' + mgmtDomainName;
111 let nav = <AppHeader title={'LAUNCHPAD' + mgmtDomainName} nav={navItems} />
114 <div className="app-body">
115 <div className="lp_dashboard">
116 <NsListPanel nsrs={self.state.nsrs}
117 openedNsrIDs={self.state.openedNsrIDs}
118 isVisible={self.state.isNsListPanelVisible}
120 <NsCardPanel nsrs={self.state.nsrs}
121 openedNsrIDs={self.state.openedNsrIDs}
122 hasAccess={hasAccess} />
128 LaunchpadApp.contextTypes = {
129 router: React.PropTypes.object,
130 userProfile: React.PropTypes.object
132 LaunchpadApp.defaultProps = {
133 // name: 'Loading...',