bodyClass.js 1.1 KB

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