mirror of
https://github.com/ansible/awx.git
synced 2026-01-14 19:30:39 -03:30
149 lines
3.7 KiB
JavaScript
149 lines
3.7 KiB
JavaScript
import React, { Component, Fragment } from 'react';
|
|
import { global_breakpoint_md } from '@patternfly/react-tokens';
|
|
import {
|
|
Nav,
|
|
NavList,
|
|
Page,
|
|
PageHeader,
|
|
PageSidebar,
|
|
} from '@patternfly/react-core';
|
|
|
|
import About from './components/About';
|
|
import NavExpandableGroup from './components/NavExpandableGroup';
|
|
import TowerLogo from './components/TowerLogo';
|
|
import PageHeaderToolbar from './components/PageHeaderToolbar';
|
|
import { ConfigContext } from './context';
|
|
|
|
class App extends Component {
|
|
constructor (props) {
|
|
super(props);
|
|
|
|
// initialize with a closed navbar if window size is small
|
|
const isNavOpen = typeof window !== 'undefined'
|
|
&& window.innerWidth >= parseInt(global_breakpoint_md.value, 10);
|
|
|
|
this.state = {
|
|
ansible_version: null,
|
|
custom_virtualenvs: null,
|
|
isAboutModalOpen: false,
|
|
isNavOpen,
|
|
version: null,
|
|
};
|
|
|
|
this.fetchConfig = this.fetchConfig.bind(this);
|
|
this.onLogout = this.onLogout.bind(this);
|
|
this.onAboutModalClose = this.onAboutModalClose.bind(this);
|
|
this.onAboutModalOpen = this.onAboutModalOpen.bind(this);
|
|
this.onNavToggle = this.onNavToggle.bind(this);
|
|
}
|
|
|
|
componentDidMount () {
|
|
this.fetchConfig();
|
|
}
|
|
|
|
async onLogout () {
|
|
const { api } = this.props;
|
|
|
|
await api.logout();
|
|
window.location.replace('/#/login');
|
|
}
|
|
|
|
onAboutModalOpen () {
|
|
this.setState({ isAboutModalOpen: true });
|
|
}
|
|
|
|
onAboutModalClose () {
|
|
this.setState({ isAboutModalOpen: false });
|
|
}
|
|
|
|
onNavToggle () {
|
|
this.setState(({ isNavOpen }) => ({ isNavOpen: !isNavOpen }));
|
|
}
|
|
|
|
async fetchConfig () {
|
|
const { api } = this.props;
|
|
|
|
try {
|
|
const { data: { ansible_version, custom_virtualenvs, version } } = await api.getConfig();
|
|
this.setState({ ansible_version, custom_virtualenvs, version });
|
|
} catch (err) {
|
|
this.setState({ ansible_version: null, custom_virtualenvs: null, version: null });
|
|
}
|
|
}
|
|
|
|
render () {
|
|
const {
|
|
ansible_version,
|
|
custom_virtualenvs,
|
|
isAboutModalOpen,
|
|
isNavOpen,
|
|
version,
|
|
} = this.state;
|
|
|
|
const {
|
|
render,
|
|
routeGroups = [],
|
|
navLabel = '',
|
|
} = this.props;
|
|
|
|
const config = {
|
|
ansible_version,
|
|
custom_virtualenvs,
|
|
version,
|
|
};
|
|
|
|
return (
|
|
<Fragment>
|
|
<Page
|
|
usecondensed="True"
|
|
header={(
|
|
<PageHeader
|
|
showNavToggle
|
|
onNavToggle={this.onNavToggle}
|
|
logo={<TowerLogo linkTo="/" />}
|
|
toolbar={(
|
|
<PageHeaderToolbar
|
|
isAboutDisabled={!version}
|
|
onAboutClick={this.onAboutModalOpen}
|
|
onLogoutClick={this.onLogout}
|
|
/>
|
|
)}
|
|
/>
|
|
)}
|
|
sidebar={(
|
|
<PageSidebar
|
|
isNavOpen={isNavOpen}
|
|
nav={(
|
|
<Nav aria-label={navLabel}>
|
|
<NavList>
|
|
{routeGroups.map(({ groupId, groupTitle, routes }) => (
|
|
<NavExpandableGroup
|
|
key={groupId}
|
|
groupId={groupId}
|
|
groupTitle={groupTitle}
|
|
routes={routes}
|
|
/>
|
|
))}
|
|
</NavList>
|
|
</Nav>
|
|
)}
|
|
/>
|
|
)}
|
|
>
|
|
<ConfigContext.Provider value={config}>
|
|
{render && render({ routeGroups })}
|
|
</ConfigContext.Provider>
|
|
</Page>
|
|
<About
|
|
ansible_version={ansible_version}
|
|
version={version}
|
|
isOpen={isAboutModalOpen}
|
|
onClose={this.onAboutModalClose}
|
|
/>
|
|
</Fragment>
|
|
);
|
|
}
|
|
}
|
|
|
|
export default App;
|