bodyClass.js 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. define([
  2. 'angular',
  3. 'lodash',
  4. 'jquery'
  5. ],
  6. function (angular, _, $) {
  7. 'use strict';
  8. angular
  9. .module('grafana.directives')
  10. .directive('bodyClass', function() {
  11. return {
  12. link: function($scope, elem) {
  13. var lastHideControlsVal;
  14. // tooltip removal fix
  15. $scope.$on("$routeChangeSuccess", function() {
  16. $("#tooltip").remove();
  17. });
  18. $scope.$watch('submenuEnabled', function() {
  19. if (!$scope.dashboard) {
  20. return;
  21. }
  22. elem.toggleClass('submenu-controls-visible', $scope.submenuEnabled);
  23. });
  24. $scope.$watch('dashboard.hideControls', function() {
  25. if (!$scope.dashboard) {
  26. return;
  27. }
  28. var hideControls = $scope.dashboard.hideControls || $scope.playlist_active;
  29. if (lastHideControlsVal !== hideControls) {
  30. elem.toggleClass('hide-controls', hideControls);
  31. lastHideControlsVal = hideControls;
  32. }
  33. });
  34. $scope.$watch('playlistSrv', function(newValue) {
  35. elem.toggleClass('playlist-active', _.isObject(newValue));
  36. });
  37. }
  38. };
  39. });
  40. });