dashboard_loaders.ts 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. import coreModule from '../core_module';
  2. export class LoadDashboardCtrl {
  3. /** @ngInject */
  4. constructor($scope, $routeParams, dashboardLoaderSrv, backendSrv, $location) {
  5. $scope.appEvent("dashboard-fetch-start");
  6. if (!$routeParams.slug) {
  7. backendSrv.get('/api/dashboards/home').then(function(homeDash) {
  8. if (homeDash.redirectUri) {
  9. $location.path('dashboard/' + homeDash.redirectUri);
  10. } else {
  11. var meta = homeDash.meta;
  12. meta.canSave = meta.canShare = meta.canStar = false;
  13. $scope.initDashboard(homeDash, $scope);
  14. }
  15. });
  16. return;
  17. }
  18. dashboardLoaderSrv.loadDashboard($routeParams.type, $routeParams.slug).then(function(result) {
  19. $scope.initDashboard(result, $scope);
  20. });
  21. }
  22. }
  23. export class NewDashboardCtrl {
  24. /** @ngInject */
  25. constructor($scope) {
  26. $scope.initDashboard({
  27. meta: { canStar: false, canShare: false, isNew: true },
  28. dashboard: {
  29. title: "New dashboard",
  30. rows: [
  31. {
  32. title: 'Dashboard Row',
  33. height: '250px',
  34. panels: [],
  35. isNew: true,
  36. }
  37. ]
  38. },
  39. }, $scope);
  40. }
  41. }
  42. coreModule.controller('LoadDashboardCtrl', LoadDashboardCtrl);
  43. coreModule.controller('NewDashboardCtrl', NewDashboardCtrl);