mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
Merge pull request #15847 from grafana/15482-go-home-with-logo
Logo takes you Home instead of toggling side menu #15482
This commit is contained in:
commit
5f6838abca
@ -2,7 +2,6 @@ import React from 'react';
|
|||||||
import { shallow } from 'enzyme';
|
import { shallow } from 'enzyme';
|
||||||
import { SideMenu } from './SideMenu';
|
import { SideMenu } from './SideMenu';
|
||||||
import appEvents from '../../app_events';
|
import appEvents from '../../app_events';
|
||||||
import { contextSrv } from 'app/core/services/context_srv';
|
|
||||||
|
|
||||||
jest.mock('../../app_events', () => ({
|
jest.mock('../../app_events', () => ({
|
||||||
emit: jest.fn(),
|
emit: jest.fn(),
|
||||||
@ -26,7 +25,6 @@ jest.mock('app/core/services/context_srv', () => ({
|
|||||||
isGrafanaAdmin: false,
|
isGrafanaAdmin: false,
|
||||||
isEditor: false,
|
isEditor: false,
|
||||||
hasEditPermissionFolders: false,
|
hasEditPermissionFolders: false,
|
||||||
toggleSideMenu: jest.fn(),
|
|
||||||
},
|
},
|
||||||
}));
|
}));
|
||||||
|
|
||||||
@ -54,20 +52,6 @@ describe('Render', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe('Functions', () => {
|
describe('Functions', () => {
|
||||||
describe('toggle side menu', () => {
|
|
||||||
const wrapper = setup();
|
|
||||||
const instance = wrapper.instance() as SideMenu;
|
|
||||||
instance.toggleSideMenu();
|
|
||||||
|
|
||||||
it('should call contextSrv.toggleSideMenu', () => {
|
|
||||||
expect(contextSrv.toggleSideMenu).toHaveBeenCalled();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should emit toggle sidemenu event', () => {
|
|
||||||
expect(appEvents.emit).toHaveBeenCalledWith('toggle-sidemenu');
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('toggle side menu on mobile', () => {
|
describe('toggle side menu on mobile', () => {
|
||||||
const wrapper = setup();
|
const wrapper = setup();
|
||||||
const instance = wrapper.instance() as SideMenu;
|
const instance = wrapper.instance() as SideMenu;
|
||||||
|
@ -1,31 +1,21 @@
|
|||||||
import React, { PureComponent } from 'react';
|
import React, { PureComponent } from 'react';
|
||||||
import appEvents from '../../app_events';
|
import appEvents from '../../app_events';
|
||||||
import { contextSrv } from 'app/core/services/context_srv';
|
|
||||||
import TopSection from './TopSection';
|
import TopSection from './TopSection';
|
||||||
import BottomSection from './BottomSection';
|
import BottomSection from './BottomSection';
|
||||||
import { store } from 'app/store/store';
|
import config from 'app/core/config';
|
||||||
|
|
||||||
|
const homeUrl = config.appSubUrl || '/';
|
||||||
|
|
||||||
export class SideMenu extends PureComponent {
|
export class SideMenu extends PureComponent {
|
||||||
toggleSideMenu = () => {
|
|
||||||
// ignore if we just made a location change, stops hiding sidemenu on double clicks of back button
|
|
||||||
const timeSinceLocationChanged = new Date().getTime() - store.getState().location.lastUpdated;
|
|
||||||
if (timeSinceLocationChanged < 1000) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
contextSrv.toggleSideMenu();
|
|
||||||
appEvents.emit('toggle-sidemenu');
|
|
||||||
};
|
|
||||||
|
|
||||||
toggleSideMenuSmallBreakpoint = () => {
|
toggleSideMenuSmallBreakpoint = () => {
|
||||||
appEvents.emit('toggle-sidemenu-mobile');
|
appEvents.emit('toggle-sidemenu-mobile');
|
||||||
};
|
};
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return [
|
return [
|
||||||
<div className="sidemenu__logo" onClick={this.toggleSideMenu} key="logo">
|
<a href={homeUrl} className="sidemenu__logo" key="logo">
|
||||||
<img src="public/img/grafana_icon.svg" alt="Grafana" />
|
<img src="public/img/grafana_icon.svg" alt="Grafana" />
|
||||||
</div>,
|
</a>,
|
||||||
<div className="sidemenu__logo_small_breakpoint" onClick={this.toggleSideMenuSmallBreakpoint} key="hamburger">
|
<div className="sidemenu__logo_small_breakpoint" onClick={this.toggleSideMenuSmallBreakpoint} key="hamburger">
|
||||||
<i className="fa fa-bars" />
|
<i className="fa fa-bars" />
|
||||||
<span className="sidemenu__close">
|
<span className="sidemenu__close">
|
||||||
|
@ -2,16 +2,16 @@
|
|||||||
|
|
||||||
exports[`Render should render component 1`] = `
|
exports[`Render should render component 1`] = `
|
||||||
Array [
|
Array [
|
||||||
<div
|
<a
|
||||||
className="sidemenu__logo"
|
className="sidemenu__logo"
|
||||||
|
href="/"
|
||||||
key="logo"
|
key="logo"
|
||||||
onClick={[Function]}
|
|
||||||
>
|
>
|
||||||
<img
|
<img
|
||||||
alt="Grafana"
|
alt="Grafana"
|
||||||
src="public/img/grafana_icon.svg"
|
src="public/img/grafana_icon.svg"
|
||||||
/>
|
/>
|
||||||
</div>,
|
</a>,
|
||||||
<div
|
<div
|
||||||
className="sidemenu__logo_small_breakpoint"
|
className="sidemenu__logo_small_breakpoint"
|
||||||
key="hamburger"
|
key="hamburger"
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
import config from 'app/core/config';
|
import config from 'app/core/config';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import coreModule from 'app/core/core_module';
|
import coreModule from 'app/core/core_module';
|
||||||
import store from 'app/core/store';
|
|
||||||
|
|
||||||
export class User {
|
export class User {
|
||||||
isGrafanaAdmin: any;
|
isGrafanaAdmin: any;
|
||||||
@ -29,13 +28,10 @@ export class ContextSrv {
|
|||||||
isSignedIn: any;
|
isSignedIn: any;
|
||||||
isGrafanaAdmin: any;
|
isGrafanaAdmin: any;
|
||||||
isEditor: any;
|
isEditor: any;
|
||||||
sidemenu: any;
|
|
||||||
sidemenuSmallBreakpoint = false;
|
sidemenuSmallBreakpoint = false;
|
||||||
hasEditPermissionInFolders: boolean;
|
hasEditPermissionInFolders: boolean;
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
this.sidemenu = store.getBool('grafana.sidemenu', true);
|
|
||||||
|
|
||||||
if (!config.bootData) {
|
if (!config.bootData) {
|
||||||
config.bootData = { user: {}, settings: {} };
|
config.bootData = { user: {}, settings: {} };
|
||||||
}
|
}
|
||||||
@ -55,11 +51,6 @@ export class ContextSrv {
|
|||||||
return !!(document.visibilityState === undefined || document.visibilityState === 'visible');
|
return !!(document.visibilityState === undefined || document.visibilityState === 'visible');
|
||||||
}
|
}
|
||||||
|
|
||||||
toggleSideMenu() {
|
|
||||||
this.sidemenu = !this.sidemenu;
|
|
||||||
store.set('grafana.sidemenu', this.sidemenu);
|
|
||||||
}
|
|
||||||
|
|
||||||
hasAccessToExplore() {
|
hasAccessToExplore() {
|
||||||
return (this.isEditor || config.viewersCanEdit) && config.exploreEnabled;
|
return (this.isEditor || config.viewersCanEdit) && config.exploreEnabled;
|
||||||
}
|
}
|
||||||
|
@ -75,27 +75,22 @@ export class GrafanaCtrl {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function setViewModeBodyClass(body: JQuery, mode: KioskUrlValue, sidemenuOpen: boolean) {
|
function setViewModeBodyClass(body: JQuery, mode: KioskUrlValue) {
|
||||||
body.removeClass('view-mode--tv');
|
body.removeClass('view-mode--tv');
|
||||||
body.removeClass('view-mode--kiosk');
|
body.removeClass('view-mode--kiosk');
|
||||||
body.removeClass('view-mode--inactive');
|
body.removeClass('view-mode--inactive');
|
||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case 'tv': {
|
case 'tv': {
|
||||||
body.removeClass('sidemenu-open');
|
|
||||||
body.addClass('view-mode--tv');
|
body.addClass('view-mode--tv');
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// 1 & true for legacy states
|
// 1 & true for legacy states
|
||||||
case '1':
|
case '1':
|
||||||
case true: {
|
case true: {
|
||||||
body.removeClass('sidemenu-open');
|
|
||||||
body.addClass('view-mode--kiosk');
|
body.addClass('view-mode--kiosk');
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default: {
|
|
||||||
body.toggleClass('sidemenu-open', sidemenuOpen);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -105,7 +100,6 @@ export function grafanaAppDirective(playlistSrv, contextSrv, $timeout, $rootScop
|
|||||||
restrict: 'E',
|
restrict: 'E',
|
||||||
controller: GrafanaCtrl,
|
controller: GrafanaCtrl,
|
||||||
link: (scope, elem) => {
|
link: (scope, elem) => {
|
||||||
let sidemenuOpen;
|
|
||||||
const body = $('body');
|
const body = $('body');
|
||||||
|
|
||||||
// see https://github.com/zenorocha/clipboard.js/issues/155
|
// see https://github.com/zenorocha/clipboard.js/issues/155
|
||||||
@ -113,14 +107,6 @@ export function grafanaAppDirective(playlistSrv, contextSrv, $timeout, $rootScop
|
|||||||
|
|
||||||
$('.preloader').remove();
|
$('.preloader').remove();
|
||||||
|
|
||||||
sidemenuOpen = scope.contextSrv.sidemenu;
|
|
||||||
body.toggleClass('sidemenu-open', sidemenuOpen);
|
|
||||||
|
|
||||||
appEvents.on('toggle-sidemenu', () => {
|
|
||||||
sidemenuOpen = scope.contextSrv.sidemenu;
|
|
||||||
body.toggleClass('sidemenu-open');
|
|
||||||
});
|
|
||||||
|
|
||||||
appEvents.on('toggle-sidemenu-mobile', () => {
|
appEvents.on('toggle-sidemenu-mobile', () => {
|
||||||
body.toggleClass('sidemenu-open--xs');
|
body.toggleClass('sidemenu-open--xs');
|
||||||
});
|
});
|
||||||
@ -163,7 +149,7 @@ export function grafanaAppDirective(playlistSrv, contextSrv, $timeout, $rootScop
|
|||||||
$('#tooltip, .tooltip').remove();
|
$('#tooltip, .tooltip').remove();
|
||||||
|
|
||||||
// check for kiosk url param
|
// check for kiosk url param
|
||||||
setViewModeBodyClass(body, data.params.kiosk, sidemenuOpen);
|
setViewModeBodyClass(body, data.params.kiosk);
|
||||||
|
|
||||||
// close all drops
|
// close all drops
|
||||||
for (const drop of Drop.drops) {
|
for (const drop of Drop.drops) {
|
||||||
@ -198,7 +184,7 @@ export function grafanaAppDirective(playlistSrv, contextSrv, $timeout, $rootScop
|
|||||||
}
|
}
|
||||||
|
|
||||||
$timeout(() => $location.search(search));
|
$timeout(() => $location.search(search));
|
||||||
setViewModeBodyClass(body, search.kiosk, sidemenuOpen);
|
setViewModeBodyClass(body, search.kiosk);
|
||||||
});
|
});
|
||||||
|
|
||||||
// handle in active view state class
|
// handle in active view state class
|
||||||
@ -218,7 +204,6 @@ export function grafanaAppDirective(playlistSrv, contextSrv, $timeout, $rootScop
|
|||||||
if (new Date().getTime() - lastActivity > inActiveTimeLimit) {
|
if (new Date().getTime() - lastActivity > inActiveTimeLimit) {
|
||||||
activeUser = false;
|
activeUser = false;
|
||||||
body.addClass('view-mode--inactive');
|
body.addClass('view-mode--inactive');
|
||||||
body.removeClass('sidemenu-open');
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -227,7 +212,6 @@ export function grafanaAppDirective(playlistSrv, contextSrv, $timeout, $rootScop
|
|||||||
if (!activeUser) {
|
if (!activeUser) {
|
||||||
activeUser = true;
|
activeUser = true;
|
||||||
body.removeClass('view-mode--inactive');
|
body.removeClass('view-mode--inactive');
|
||||||
body.toggleClass('sidemenu-open', sidemenuOpen);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -157,14 +157,8 @@
|
|||||||
|
|
||||||
@include media-breakpoint-up(sm) {
|
@include media-breakpoint-up(sm) {
|
||||||
.navbar {
|
.navbar {
|
||||||
padding-left: 60px;
|
padding-left: 20px;
|
||||||
}
|
margin-left: 0;
|
||||||
|
|
||||||
.sidemenu-open {
|
|
||||||
.navbar {
|
|
||||||
padding-left: 25px;
|
|
||||||
margin-left: 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.navbar-page-btn {
|
.navbar-page-btn {
|
||||||
|
@ -16,6 +16,14 @@
|
|||||||
.sidemenu__close {
|
.sidemenu__close {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@include media-breakpoint-up(sm) {
|
||||||
|
background: $side-menu-bg;
|
||||||
|
height: auto;
|
||||||
|
box-shadow: $side-menu-shadow;
|
||||||
|
position: relative;
|
||||||
|
z-index: $zindex-sidemenu;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// body class that hides sidemenu
|
// body class that hides sidemenu
|
||||||
@ -25,32 +33,22 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@include media-breakpoint-up(sm) {
|
|
||||||
.sidemenu-open {
|
|
||||||
.sidemenu {
|
|
||||||
background: $side-menu-bg;
|
|
||||||
height: auto;
|
|
||||||
box-shadow: $side-menu-shadow;
|
|
||||||
position: relative;
|
|
||||||
z-index: $zindex-sidemenu;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidemenu__top,
|
|
||||||
.sidemenu__bottom {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidemenu__top {
|
.sidemenu__top {
|
||||||
padding-top: 3rem;
|
padding-top: 3rem;
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
display: none;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.sidemenu__bottom {
|
.sidemenu__bottom {
|
||||||
padding-bottom: $spacer;
|
padding-bottom: $spacer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidemenu__top,
|
||||||
|
.sidemenu__bottom {
|
||||||
display: none;
|
display: none;
|
||||||
|
|
||||||
|
@include media-breakpoint-up(sm) {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.sidemenu-item {
|
.sidemenu-item {
|
||||||
|
@ -29,6 +29,21 @@
|
|||||||
.view-mode--tv {
|
.view-mode--tv {
|
||||||
@extend .view-mode--inactive;
|
@extend .view-mode--inactive;
|
||||||
|
|
||||||
|
.sidemenu {
|
||||||
|
position: fixed;
|
||||||
|
background-color: transparent;
|
||||||
|
box-shadow: none;
|
||||||
|
|
||||||
|
.sidemenu__top,
|
||||||
|
.sidemenu__bottom {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar {
|
||||||
|
padding-left: $side-menu-width;
|
||||||
|
}
|
||||||
|
|
||||||
.submenu-controls {
|
.submenu-controls {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
@ -25,20 +25,13 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.sidemenu-open {
|
|
||||||
.explore-toolbar-header {
|
|
||||||
padding: 0;
|
|
||||||
margin-left: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.explore-toolbar {
|
.explore-toolbar {
|
||||||
background: inherit;
|
background: inherit;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-flow: row wrap;
|
flex-flow: row wrap;
|
||||||
justify-content: flex-start;
|
justify-content: flex-start;
|
||||||
height: auto;
|
height: auto;
|
||||||
padding: 0px $dashboard-padding 0 25px;
|
padding: 0 $dashboard-padding;
|
||||||
border-bottom: 1px solid #0000;
|
border-bottom: 1px solid #0000;
|
||||||
transition-duration: 0.35s;
|
transition-duration: 0.35s;
|
||||||
transition-timing-function: ease-in-out;
|
transition-timing-function: ease-in-out;
|
||||||
@ -72,11 +65,6 @@
|
|||||||
font-size: 18px;
|
font-size: 18px;
|
||||||
min-height: 55px;
|
min-height: 55px;
|
||||||
line-height: 55px;
|
line-height: 55px;
|
||||||
justify-content: space-between;
|
|
||||||
margin-left: $panel-margin * 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
.explore-toolbar-header {
|
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
}
|
}
|
||||||
@ -134,20 +122,6 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
@media only screen and (max-width: 803px) {
|
@media only screen and (max-width: 803px) {
|
||||||
.sidemenu-open {
|
|
||||||
.explore-toolbar-header-title {
|
|
||||||
.navbar-page-btn {
|
|
||||||
margin-left: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.explore-toolbar-header-title {
|
|
||||||
.navbar-page-btn {
|
|
||||||
margin-left: $dashboard-padding;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn-title {
|
.btn-title {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
@ -161,14 +135,6 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
@media only screen and (max-width: 544px) {
|
@media only screen and (max-width: 544px) {
|
||||||
.sidemenu-open {
|
|
||||||
.explore-toolbar-header-title {
|
|
||||||
.navbar-page-btn {
|
|
||||||
margin-left: $dashboard-padding;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.explore-toolbar-header-title {
|
.explore-toolbar-header-title {
|
||||||
.navbar-page-btn {
|
.navbar-page-btn {
|
||||||
margin-left: $dashboard-padding;
|
margin-left: $dashboard-padding;
|
||||||
|
Loading…
Reference in New Issue
Block a user