dashboard_loaders.ts 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  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. if ($routeParams.keepRows) {
  20. result.meta.keepRows = true;
  21. }
  22. $scope.initDashboard(result, $scope);
  23. });
  24. }
  25. }
  26. export class NewDashboardCtrl {
  27. /** @ngInject */
  28. constructor($scope, $routeParams) {
  29. $scope.initDashboard({
  30. meta: { canStar: false, canShare: false, isNew: true },
  31. dashboard: {
  32. title: "New dashboard",
  33. panels: [
  34. {
  35. type: 'add-panel',
  36. gridPos: {x: 0, y: 0, w: 12, h: 9},
  37. title: 'Panel Title',
  38. }
  39. ],
  40. folderId: Number($routeParams.folderId)
  41. },
  42. }, $scope);
  43. }
  44. }
  45. coreModule.controller('LoadDashboardCtrl', LoadDashboardCtrl);
  46. coreModule.controller('NewDashboardCtrl', NewDashboardCtrl);