dash_class.ts 1.1 KB

123456789101112131415161718192021222324252627282930
  1. import _ from 'lodash';
  2. import coreModule from '../core_module';
  3. coreModule.directive('dashClass', function($timeout) {
  4. return {
  5. link: function($scope, elem) {
  6. $scope.ctrl.dashboard.events.on('view-mode-changed', function(panel) {
  7. elem.toggleClass('panel-in-fullscreen', panel.fullscreen === true);
  8. });
  9. elem.toggleClass('panel-in-fullscreen', $scope.ctrl.dashboard.meta.fullscreen === true);
  10. $scope.$watch('ctrl.playlistSrv.isPlaying', function(newValue) {
  11. elem.toggleClass('playlist-active', newValue === true);
  12. });
  13. $scope.$watch('ctrl.dashboardViewState.state.editview', function(newValue) {
  14. if (newValue) {
  15. elem.toggleClass('dashboard-page--settings-opening', _.isString(newValue));
  16. setTimeout(function() {
  17. elem.toggleClass('dashboard-page--settings-open', _.isString(newValue));
  18. }, 10);
  19. } else {
  20. elem.removeClass('dashboard-page--settings-opening');
  21. elem.removeClass('dashboard-page--settings-open');
  22. }
  23. });
  24. },
  25. };
  26. });