grafana/public/app/features/users/UsersActionBar.tsx

99 lines
2.9 KiB
TypeScript
Raw Normal View History

2018-10-03 02:43:10 -05:00
import React, { PureComponent } from 'react';
import { connect } from 'react-redux';
2018-12-25 04:42:23 -06:00
import classNames from 'classnames';
2018-10-03 02:43:10 -05:00
import { setUsersSearchQuery } from './state/actions';
import { getInviteesCount, getUsersSearchQuery } from './state/selectors';
import { FilterInput } from 'app/core/components/FilterInput/FilterInput';
2018-10-03 02:43:10 -05:00
export interface Props {
searchQuery: string;
setUsersSearchQuery: typeof setUsersSearchQuery;
2018-10-03 03:54:15 -05:00
onShowInvites: () => void;
2018-10-03 02:43:10 -05:00
pendingInvitesCount: number;
canInvite: boolean;
2018-10-03 06:04:31 -05:00
showInvites: boolean;
2018-10-03 02:43:10 -05:00
externalUserMngLinkUrl: string;
externalUserMngLinkName: string;
}
export class UsersActionBar extends PureComponent<Props> {
render() {
const {
canInvite,
externalUserMngLinkName,
externalUserMngLinkUrl,
searchQuery,
pendingInvitesCount,
setUsersSearchQuery,
2018-10-03 03:54:15 -05:00
onShowInvites,
2018-10-03 06:04:31 -05:00
showInvites,
2018-10-03 02:43:10 -05:00
} = this.props;
2018-10-03 06:04:31 -05:00
const pendingInvitesButtonStyle = classNames({
btn: true,
'toggle-btn': true,
active: showInvites,
});
const usersButtonStyle = classNames({
btn: true,
'toggle-btn': true,
active: !showInvites,
});
2018-10-03 02:43:10 -05:00
return (
<div className="page-action-bar">
<div className="gf-form gf-form--grow">
<FilterInput
labelClassName="gf-form--has-input-icon"
inputClassName="gf-form-input width-20"
value={searchQuery}
onChange={setUsersSearchQuery}
placeholder="Filter by name or type"
/>
2018-10-03 02:43:10 -05:00
{pendingInvitesCount > 0 && (
2018-10-03 06:04:31 -05:00
<div style={{ marginLeft: '1rem' }}>
<button className={usersButtonStyle} key="users" onClick={onShowInvites}>
Users
</button>
<button className={pendingInvitesButtonStyle} onClick={onShowInvites} key="pending-invites">
Pending Invites ({pendingInvitesCount})
</button>
</div>
2018-10-03 02:43:10 -05:00
)}
2018-10-03 06:04:31 -05:00
<div className="page-action-bar__spacer" />
2018-10-03 02:43:10 -05:00
{canInvite && (
<a className="btn btn-primary" href="org/users/invite">
2018-10-03 02:43:10 -05:00
<span>Invite</span>
</a>
)}
{externalUserMngLinkUrl && (
<a className="btn btn-primary" href={externalUserMngLinkUrl} target="_blank" rel="noopener">
<i className="fa fa-external-link-square" /> {externalUserMngLinkName}
2018-10-03 02:43:10 -05:00
</a>
)}
</div>
</div>
);
}
}
function mapStateToProps(state: any) {
2018-10-03 02:43:10 -05:00
return {
searchQuery: getUsersSearchQuery(state.users),
pendingInvitesCount: getInviteesCount(state.users),
externalUserMngLinkName: state.users.externalUserMngLinkName,
externalUserMngLinkUrl: state.users.externalUserMngLinkUrl,
canInvite: state.users.canInvite,
};
}
const mapDispatchToProps = {
setUsersSearchQuery,
};
export default connect(
mapStateToProps,
mapDispatchToProps
)(UsersActionBar);