UsersActionBar.tsx 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. import React, { PureComponent } from 'react';
  2. import { connect } from 'react-redux';
  3. import classNames from 'classnames';
  4. import { setUsersSearchQuery } from './state/actions';
  5. import { getInviteesCount, getUsersSearchQuery } from './state/selectors';
  6. import { FilterInput } from 'app/core/components/FilterInput/FilterInput';
  7. export interface Props {
  8. searchQuery: string;
  9. setUsersSearchQuery: typeof setUsersSearchQuery;
  10. onShowInvites: () => void;
  11. pendingInvitesCount: number;
  12. canInvite: boolean;
  13. showInvites: boolean;
  14. externalUserMngLinkUrl: string;
  15. externalUserMngLinkName: string;
  16. }
  17. export class UsersActionBar extends PureComponent<Props> {
  18. render() {
  19. const {
  20. canInvite,
  21. externalUserMngLinkName,
  22. externalUserMngLinkUrl,
  23. searchQuery,
  24. pendingInvitesCount,
  25. setUsersSearchQuery,
  26. onShowInvites,
  27. showInvites,
  28. } = this.props;
  29. const pendingInvitesButtonStyle = classNames({
  30. btn: true,
  31. 'toggle-btn': true,
  32. active: showInvites,
  33. });
  34. const usersButtonStyle = classNames({
  35. btn: true,
  36. 'toggle-btn': true,
  37. active: !showInvites,
  38. });
  39. return (
  40. <div className="page-action-bar">
  41. <div className="gf-form gf-form--grow">
  42. <FilterInput
  43. labelClassName="gf-form--has-input-icon"
  44. inputClassName="gf-form-input width-20"
  45. value={searchQuery}
  46. onChange={setUsersSearchQuery}
  47. placeholder="Filter by name or type"
  48. />
  49. {pendingInvitesCount > 0 && (
  50. <div style={{ marginLeft: '1rem' }}>
  51. <button className={usersButtonStyle} key="users" onClick={onShowInvites}>
  52. Users
  53. </button>
  54. <button className={pendingInvitesButtonStyle} onClick={onShowInvites} key="pending-invites">
  55. Pending Invites ({pendingInvitesCount})
  56. </button>
  57. </div>
  58. )}
  59. <div className="page-action-bar__spacer" />
  60. {canInvite && (
  61. <a className="btn btn-primary" href="org/users/invite">
  62. <span>Invite</span>
  63. </a>
  64. )}
  65. {externalUserMngLinkUrl && (
  66. <a className="btn btn-primary" href={externalUserMngLinkUrl} target="_blank">
  67. <i className="fa fa-external-link-square" /> {externalUserMngLinkName}
  68. </a>
  69. )}
  70. </div>
  71. </div>
  72. );
  73. }
  74. }
  75. function mapStateToProps(state) {
  76. return {
  77. searchQuery: getUsersSearchQuery(state.users),
  78. pendingInvitesCount: getInviteesCount(state.users),
  79. externalUserMngLinkName: state.users.externalUserMngLinkName,
  80. externalUserMngLinkUrl: state.users.externalUserMngLinkUrl,
  81. canInvite: state.users.canInvite,
  82. };
  83. }
  84. const mapDispatchToProps = {
  85. setUsersSearchQuery,
  86. };
  87. export default connect(
  88. mapStateToProps,
  89. mapDispatchToProps
  90. )(UsersActionBar);