PanelHeader.tsx 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. import React, { PureComponent } from 'react';
  2. import classNames from 'classnames';
  3. interface Props {
  4. title: string;
  5. }
  6. export class PanelHeader extends PureComponent<Props> {
  7. render() {
  8. const isFullscreen = false;
  9. const isLoading = false;
  10. const panelHeaderClass = classNames({ 'panel-header': true, 'grid-drag-handle': !isFullscreen });
  11. const { title } = this.props;
  12. return (
  13. <div className={panelHeaderClass}>
  14. <span className="panel-info-corner">
  15. <i className="fa" />
  16. <span className="panel-info-corner-inner" />
  17. </span>
  18. {isLoading && (
  19. <span className="panel-loading">
  20. <i className="fa fa-spinner fa-spin" />
  21. </span>
  22. )}
  23. <div className="panel-title-container">
  24. <div className="panel-title">
  25. <span className="icon-gf panel-alert-icon" />
  26. <span className="panel-title-text" data-toggle="dropdown">
  27. {title} <span className="fa fa-caret-down panel-menu-toggle" />
  28. </span>
  29. {this.props.children}
  30. <span className="panel-time-info">
  31. <i className="fa fa-clock-o" /> 4m
  32. </span>
  33. </div>
  34. </div>
  35. </div>
  36. );
  37. }
  38. }