OrgActionBar.tsx 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. import React, { PureComponent } from 'react';
  2. import LayoutSelector, { LayoutMode } from '../LayoutSelector/LayoutSelector';
  3. import { RegExpSafeInput } from '../RegExpSafeInput/RegExpSafeInput';
  4. export interface Props {
  5. searchQuery: string;
  6. layoutMode?: LayoutMode;
  7. onSetLayoutMode?: (mode: LayoutMode) => {};
  8. setSearchQuery: (value: string) => {};
  9. linkButton: { href: string; title: string };
  10. target?: string;
  11. }
  12. export default class OrgActionBar extends PureComponent<Props> {
  13. render() {
  14. const { searchQuery, layoutMode, onSetLayoutMode, linkButton, setSearchQuery, target } = this.props;
  15. const linkProps = { href: linkButton.href, target: undefined };
  16. if (target) {
  17. linkProps.target = target;
  18. }
  19. return (
  20. <div className="page-action-bar">
  21. <div className="gf-form gf-form--grow">
  22. <label className="gf-form--has-input-icon">
  23. <RegExpSafeInput
  24. className={'gf-form-input width-20'}
  25. value={searchQuery}
  26. onChange={setSearchQuery}
  27. placeholder={'Filter by name or type'}
  28. />
  29. <i className="gf-form-input-icon fa fa-search" />
  30. </label>
  31. <LayoutSelector mode={layoutMode} onLayoutModeChanged={(mode: LayoutMode) => onSetLayoutMode(mode)} />
  32. </div>
  33. <div className="page-action-bar__spacer" />
  34. <a className="btn btn-primary" {...linkProps}>
  35. {linkButton.title}
  36. </a>
  37. </div>
  38. );
  39. }
  40. }