Explorar el Código

Closing timepicker when clicking outside the picker

Hugo Häggmark hace 7 años
padre
commit
e42b670f5c
Se han modificado 1 ficheros con 8 adiciones y 1 borrados
  1. 8 1
      public/app/features/explore/ExploreToolbar.tsx

+ 8 - 1
public/app/features/explore/ExploreToolbar.tsx

@@ -8,6 +8,7 @@ import { DataSourcePicker } from 'app/core/components/Select/DataSourcePicker';
 import { StoreState } from 'app/types/store';
 import { StoreState } from 'app/types/store';
 import { changeDatasource, clearQueries, splitClose, runQueries, splitOpen } from './state/actions';
 import { changeDatasource, clearQueries, splitClose, runQueries, splitOpen } from './state/actions';
 import TimePicker from './TimePicker';
 import TimePicker from './TimePicker';
+import { ClickOutsideWrapper } from 'app/core/components/ClickOutsideWrapper/ClickOutsideWrapper';
 
 
 enum IconSide {
 enum IconSide {
   left = 'left',
   left = 'left',
@@ -79,6 +80,10 @@ export class UnConnectedExploreToolbar extends PureComponent<Props, {}> {
     this.props.runQuery(this.props.exploreId);
     this.props.runQuery(this.props.exploreId);
   };
   };
 
 
+  onCloseTimePicker = () => {
+    this.props.timepickerRef.current.setState({ isOpen: false });
+  };
+
   render() {
   render() {
     const {
     const {
       datasourceMissing,
       datasourceMissing,
@@ -137,7 +142,9 @@ export class UnConnectedExploreToolbar extends PureComponent<Props, {}> {
               </div>
               </div>
             ) : null}
             ) : null}
             <div className="explore-toolbar-content-item timepicker">
             <div className="explore-toolbar-content-item timepicker">
-              <TimePicker ref={timepickerRef} range={range} onChangeTime={this.props.onChangeTime} />
+              <ClickOutsideWrapper onClick={this.onCloseTimePicker}>
+                <TimePicker ref={timepickerRef} range={range} onChangeTime={this.props.onChangeTime} />
+              </ClickOutsideWrapper>
             </div>
             </div>
             <div className="explore-toolbar-content-item">
             <div className="explore-toolbar-content-item">
               <button className="btn navbar-button navbar-button--no-icon" onClick={this.onClearAll}>
               <button className="btn navbar-button navbar-button--no-icon" onClick={this.onClearAll}>