| 123456789101112131415161718192021222324252627282930313233343536373839404142 |
- import React, { PureComponent } from 'react';
- import LayoutSelector, { LayoutMode } from '../LayoutSelector/LayoutSelector';
- import { FilterInput } from '../FilterInput/FilterInput';
- export interface Props {
- searchQuery: string;
- layoutMode?: LayoutMode;
- onSetLayoutMode?: (mode: LayoutMode) => {};
- setSearchQuery: (value: string) => {};
- linkButton: { href: string; title: string };
- target?: string;
- }
- export default class OrgActionBar extends PureComponent<Props> {
- render() {
- const { searchQuery, layoutMode, onSetLayoutMode, linkButton, setSearchQuery, target } = this.props;
- const linkProps = { href: linkButton.href, target: undefined };
- if (target) {
- linkProps.target = target;
- }
- 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={setSearchQuery}
- placeholder={'Filter by name or type'}
- />
- <LayoutSelector mode={layoutMode} onLayoutModeChanged={(mode: LayoutMode) => onSetLayoutMode(mode)} />
- </div>
- <div className="page-action-bar__spacer" />
- <a className="btn btn-primary" {...linkProps}>
- {linkButton.title}
- </a>
- </div>
- );
- }
- }
|