grafana/public/app/features/teams/CreateTeam.tsx
Jack Westbrook 249004ebef
Pages: update react components to use v2 theme (#33413)
* chore: expose theme types / functions

* fix(grafana-ui): withTheme2 extends themeable2

* feat: migrate page components to use new theme

* refactor(pages): replace legacy form components with latest form components

* refactor(dashboardimport): update page component to use theme spacing

* refactor(alerting-ng): update page component to use v2 theme

* test(dashboardpage): update test for v2 theme

* test(apikeyspage): update test to select InlineSwitch component

* test(createteam): update snapshot

* refactor(playlist): update page components to use v2 theme

* refactor(page): put back classes on page-container and background colors
2021-04-28 16:05:00 +02:00

72 lines
2.2 KiB
TypeScript

import React, { PureComponent } from 'react';
import Page from 'app/core/components/Page/Page';
import { hot } from 'react-hot-loader';
import { Button, Form, Field, Input, FieldSet, Label, Tooltip, Icon } from '@grafana/ui';
import { NavModel } from '@grafana/data';
import { getBackendSrv, locationService } from '@grafana/runtime';
import { connect } from 'react-redux';
import { getNavModel } from 'app/core/selectors/navModel';
import { StoreState } from 'app/types';
export interface Props {
navModel: NavModel;
}
interface TeamDTO {
name: string;
email: string;
}
export class CreateTeam extends PureComponent<Props> {
create = async (formModel: TeamDTO) => {
const result = await getBackendSrv().post('/api/teams', formModel);
if (result.teamId) {
locationService.push(`/org/teams/edit/${result.teamId}`);
}
};
render() {
const { navModel } = this.props;
return (
<Page navModel={navModel}>
<Page.Contents>
<Form onSubmit={this.create}>
{({ register }) => (
<FieldSet label="New Team">
<Field label="Name">
<Input name="name" ref={register({ required: true })} width={60} />
</Field>
<Field
label={
<Label>
<span>Email</span>
<Tooltip content="This is optional and is primarily used for allowing custom team avatars.">
<Icon name="info-circle" style={{ marginLeft: 6 }} />
</Tooltip>
</Label>
}
>
<Input type="email" name="email" ref={register()} placeholder="email@test.com" width={60} />
</Field>
<div className="gf-form-button-row">
<Button type="submit" variant="primary">
Create
</Button>
</div>
</FieldSet>
)}
</Form>
</Page.Contents>
</Page>
);
}
}
function mapStateToProps(state: StoreState) {
return {
navModel: getNavModel(state.navIndex, 'teams'),
};
}
export default hot(module)(connect(mapStateToProps)(CreateTeam));