1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- import React, { FC } from 'react';
- import { connect, ConnectedProps } from 'react-redux';
- import { Button, Input, Field, Form } from '@grafana/ui';
- import Page from 'app/core/components/Page/Page';
- import { getConfig } from 'app/core/config';
- import { StoreState } from 'app/types';
- import { getNavModel } from '../../core/selectors/navModel';
- import { createOrganization } from './state/actions';
- const mapStateToProps = (state: StoreState) => {
- return { navModel: getNavModel(state.navIndex, 'global-orgs') };
- };
- const mapDispatchToProps = {
- createOrganization,
- };
- const connector = connect(mapStateToProps, mapDispatchToProps);
- type Props = ConnectedProps<typeof connector>;
- interface CreateOrgFormDTO {
- name: string;
- }
- export const NewOrgPage: FC<Props> = ({ navModel, createOrganization }) => {
- const createOrg = async (newOrg: { name: string }) => {
- await createOrganization(newOrg);
- window.location.href = getConfig().appSubUrl + '/org';
- };
- return (
- <Page navModel={navModel}>
- <Page.Contents>
- <h3 className="page-sub-heading">New organization</h3>
- <p className="playlist-description">
- Each organization contains their own dashboards, data sources, and configuration, which cannot be shared
- shared between organizations. While users might belong to more than one organization, multiple organizations
- are most frequently used in multi-tenant deployments.{' '}
- </p>
- <Form<CreateOrgFormDTO> onSubmit={createOrg}>
- {({ register, errors }) => {
- return (
- <>
- <Field label="Organization name" invalid={!!errors.name} error={errors.name && errors.name.message}>
- <Input
- placeholder="Org name"
- {...register('name', {
- required: 'Organization name is required',
- })}
- />
- </Field>
- <Button type="submit">Create</Button>
- </>
- );
- }}
- </Form>
- </Page.Contents>
- </Page>
- );
- };
- export default connector(NewOrgPage);
|