import React, { PureComponent } from 'react'; import { css, cx } from 'emotion'; import { Modal, Themeable, stylesFactory, withTheme, ConfirmButton, Forms } from '@grafana/ui'; import { GrafanaTheme } from '@grafana/data'; import { UserOrg, Organization } from 'app/types'; import { OrgPicker, OrgSelectItem } from 'app/core/components/Select/OrgPicker'; interface Props { orgs: UserOrg[]; onOrgRemove: (orgId: number) => void; onOrgRoleChange: (orgId: number, newRole: string) => void; onOrgAdd: (orgId: number, role: string) => void; } interface State { showAddOrgModal: boolean; } export class UserOrgs extends PureComponent { state = { showAddOrgModal: false, }; showOrgAddModal = (show: boolean) => () => { this.setState({ showAddOrgModal: show }); }; render() { const { orgs, onOrgRoleChange, onOrgRemove, onOrgAdd } = this.props; const { showAddOrgModal } = this.state; const addToOrgContainerClass = css` margin-top: 0.8rem; `; return ( <>

Organisations

{orgs.map((org, index) => ( ))}
Add user to organization
); } } const ORG_ROLES = ['Viewer', 'Editor', 'Admin']; const getOrgRowStyles = stylesFactory((theme: GrafanaTheme) => { return { removeButton: css` margin-right: 0.6rem; text-decoration: underline; color: ${theme.colors.blue95}; `, label: css` font-weight: 500; `, }; }); interface OrgRowProps extends Themeable { org: UserOrg; onOrgRemove: (orgId: number) => void; onOrgRoleChange: (orgId: number, newRole: string) => void; } interface OrgRowState { currentRole: string; isChangingRole: boolean; isRemovingFromOrg: boolean; } class UnThemedOrgRow extends PureComponent { state = { currentRole: this.props.org.role, isChangingRole: false, isRemovingFromOrg: false, }; onOrgRemove = () => { const { org } = this.props; this.props.onOrgRemove(org.orgId); }; onChangeRoleClick = () => { const { org } = this.props; this.setState({ isChangingRole: true, currentRole: org.role }); }; onOrgRemoveClick = () => { this.setState({ isRemovingFromOrg: true }); }; onOrgRoleChange = (event: React.ChangeEvent) => { const newRole = event.target.value; this.setState({ currentRole: newRole }); }; onOrgRoleSave = () => { this.props.onOrgRoleChange(this.props.org.orgId, this.state.currentRole); }; onCancelClick = () => { this.setState({ isChangingRole: false, isRemovingFromOrg: false }); }; render() { const { org, theme } = this.props; const { currentRole, isChangingRole, isRemovingFromOrg } = this.state; const styles = getOrgRowStyles(theme); const labelClass = cx('width-16', styles.label); return ( {org.name} {isChangingRole ? (
) : ( {org.role} )} {!isRemovingFromOrg && (
Change role
)} {!isChangingRole && (
Remove from organisation
)} ); } } const OrgRow = withTheme(UnThemedOrgRow); const getAddToOrgModalStyles = stylesFactory(() => ({ modal: css` width: 500px; `, buttonRow: css` text-align: center; `, })); interface AddToOrgModalProps { isOpen: boolean; onOrgAdd(orgId: number, role: string): void; onDismiss?(): void; } interface AddToOrgModalState { selectedOrg: Organization; role: string; } export class AddToOrgModal extends PureComponent { state: AddToOrgModalState = { selectedOrg: null, role: 'Admin', }; onOrgSelect = (org: OrgSelectItem) => { this.setState({ selectedOrg: { ...org } }); }; onOrgRoleChange = (event: React.ChangeEvent) => { this.setState({ role: event.target.value, }); }; onAddUserToOrg = () => { const { selectedOrg, role } = this.state; this.props.onOrgAdd(selectedOrg.id, role); }; onCancel = () => { this.props.onDismiss(); }; render() { const { isOpen } = this.props; const { role } = this.state; const styles = getAddToOrgModalStyles(); const buttonRowClass = cx('gf-form-button-row', styles.buttonRow); return (
Organisation
Role
Add to organization Cancel
); } }