Merge pull request #12757 from influxdata/move-create-org-overlay-router

Move create organization overlay to route
pull/12820/head
Brandon Farmer 2019-03-21 09:30:20 -07:00 committed by GitHub
commit ab7f123df5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 90 additions and 73 deletions

View File

@ -52,6 +52,7 @@ import NoteEditorOverlay from 'src/dashboards/components/NoteEditorOverlay'
import OrgTemplatesIndex from 'src/organizations/containers/OrgTemplatesIndex'
import TemplateExportOverlay from 'src/templates/components/TemplateExportOverlay'
import TemplateImportOverlay from 'src/templates/components/TemplateImportOverlay'
import CreateOrgOverlay from './organizations/components/CreateOrgOverlay'
import OnboardingWizardPage from 'src/onboarding/containers/OnboardingWizardPage'
@ -117,8 +118,19 @@ class Root extends PureComponent {
<Route component={GetOrganizations}>
<Route component={App}>
<IndexRoute component={MePage} />
<Route
path="organizations"
component={OrganizationsIndex}
>
<Route path="new" component={CreateOrgOverlay} />
</Route>
<Route path="organizations">
<IndexRoute component={OrganizationsIndex} />
<Route component={OrganizationsIndex}>
<Route path="new" component={CreateOrgOverlay} />
</Route>
<Route path=":orgID">
<Route path="buckets" component={OrgBucketIndex} />
<Route

View File

@ -1,5 +1,8 @@
// Libraries
import React, {PureComponent, ChangeEvent} from 'react'
import {connect} from 'react-redux'
import {WithRouterProps, withRouter} from 'react-router'
import _ from 'lodash'
// Components
@ -13,21 +16,25 @@ import {Form, Overlay, Input} from 'src/clockface'
// Types
import {Organization} from '@influxdata/influx'
// Actions
import {createOrg} from 'src/organizations/actions/orgs'
interface Props {
link: string
onCreateOrg: typeof createOrg
onCloseModal: () => void
interface OwnProps {}
interface DispatchProps {
createOrg: typeof createOrg
}
type Props = OwnProps & DispatchProps & WithRouterProps
interface State {
org: Organization
nameInputStatus: ComponentStatus
errorMessage: string
}
export default class CreateOrgOverlay extends PureComponent<Props, State> {
class CreateOrgOverlay extends PureComponent<Props, State> {
constructor(props) {
super(props)
this.state = {
@ -38,14 +45,14 @@ export default class CreateOrgOverlay extends PureComponent<Props, State> {
}
public render() {
const {onCloseModal} = this.props
const {org, nameInputStatus, errorMessage} = this.state
return (
<Overlay visible={true}>
<Overlay.Container maxWidth={500}>
<Overlay.Heading
title="Create Organization"
onDismiss={this.props.onCloseModal}
onDismiss={this.closeModal}
/>
<Form onSubmit={this.handleCreateOrg}>
<Overlay.Body>
@ -62,7 +69,7 @@ export default class CreateOrgOverlay extends PureComponent<Props, State> {
</Form.Element>
</Overlay.Body>
<Overlay.Footer>
<Button text="Cancel" onClick={onCloseModal} />
<Button text="Cancel" onClick={this.closeModal} />
<Button
text="Create"
type={ButtonType.Submit}
@ -73,6 +80,7 @@ export default class CreateOrgOverlay extends PureComponent<Props, State> {
</Overlay.Footer>
</Form>
</Overlay.Container>
</Overlay>
)
}
@ -88,9 +96,14 @@ export default class CreateOrgOverlay extends PureComponent<Props, State> {
private handleCreateOrg = async () => {
const {org} = this.state
const {onCreateOrg, onCloseModal} = this.props
await onCreateOrg(org)
onCloseModal()
const {createOrg} = this.props
await createOrg(org)
this.closeModal()
}
private closeModal = () => {
this.props.router.goBack()
}
private handleChangeInput = (e: ChangeEvent<HTMLInputElement>) => {
@ -126,3 +139,14 @@ export default class CreateOrgOverlay extends PureComponent<Props, State> {
return _.sample(messages)
}
}
const mdtp = {
createOrg,
}
export default withRouter(
connect<{}, DispatchProps, OwnProps>(
null,
mdtp
)(CreateOrgOverlay)
)

View File

@ -1,19 +1,17 @@
// Libraries
import React, {PureComponent} from 'react'
import {WithRouterProps} from 'react-router'
import {WithRouterProps, withRouter} from 'react-router'
import {connect} from 'react-redux'
import _ from 'lodash'
// Components
import {Page} from 'src/pageLayout'
import CreateOrgOverlay from 'src/organizations/components/CreateOrgOverlay'
import OrganizationsIndexContents from 'src/organizations/components/OrganizationsIndexContents'
import SearchWidget from 'src/shared/components/search_widget/SearchWidget'
import {Button, IconFont, ComponentColor} from '@influxdata/clockface'
import {Overlay} from 'src/clockface'
// Actions
import {createOrg, deleteOrg} from 'src/organizations/actions/orgs'
import {deleteOrg} from 'src/organizations/actions/orgs'
// Types
import {Organization, Links} from 'src/types/v2'
@ -28,32 +26,24 @@ interface StateProps {
}
interface DispatchProps {
onCreateOrg: typeof createOrg
onDeleteOrg: typeof deleteOrg
}
interface State {
modalState: ModalState
searchTerm: string
}
enum ModalState {
Open = 'open',
Closed = 'closed',
}
type Props = StateProps & DispatchProps & WithRouterProps
@ErrorHandling
class OrganizationsIndex extends PureComponent<Props, State> {
public state: State = {
modalState: ModalState.Closed,
searchTerm: '',
}
public render() {
const {links, onCreateOrg, onDeleteOrg, orgs} = this.props
const {modalState, searchTerm} = this.state
const {onDeleteOrg, orgs, children} = this.props
const {searchTerm} = this.state
return (
<>
@ -93,28 +83,18 @@ class OrganizationsIndex extends PureComponent<Props, State> {
</FilterList>
</Page.Contents>
</Page>
<Overlay visible={modalState === ModalState.Open}>
<CreateOrgOverlay
link={links.orgs}
onCloseModal={this.handleCloseModal}
onCreateOrg={onCreateOrg}
/>
</Overlay>
{children}
</>
)
}
private handleOpenModal = (): void => {
this.setState({modalState: ModalState.Open})
}
private handleCloseModal = (): void => {
this.setState({modalState: ModalState.Closed})
}
private handleChangeSearchTerm = (searchTerm: string): void => {
this.setState({searchTerm})
}
private handleOpenModal = () => {
this.props.router.push(`${this.props.location.pathname}/new`)
}
}
const mstp = (state): StateProps => {
@ -127,11 +107,12 @@ const mstp = (state): StateProps => {
}
const mdtp: DispatchProps = {
onCreateOrg: createOrg,
onDeleteOrg: deleteOrg,
}
export default connect<StateProps, DispatchProps>(
export default withRouter(
connect<StateProps, DispatchProps>(
mstp,
mdtp
)(OrganizationsIndex)
)