import coreModule from 'app/core/core_module'; import locationUtil from 'app/core/utils/location_util'; export class LoadDashboardCtrl { /** @ngInject */ constructor($scope, $routeParams, dashboardLoaderSrv, backendSrv, $location, $browser) { $scope.appEvent('dashboard-fetch-start'); if (!$routeParams.uid && !$routeParams.slug) { backendSrv.get('/api/dashboards/home').then(function(homeDash) { if (homeDash.redirectUri) { $location.path(homeDash.redirectUri); } else { var meta = homeDash.meta; meta.canSave = meta.canShare = meta.canStar = false; $scope.initDashboard(homeDash, $scope); } }); return; } // if no uid, redirect to new route based on slug if (!($routeParams.type === 'script' || $routeParams.type === 'snapshot') && !$routeParams.uid) { backendSrv.get(`/api/dashboards/db/${$routeParams.slug}`).then(res => { if (res) { $location.path(locationUtil.stripBaseFromUrl(res.meta.url)).replace(); } }); return; } dashboardLoaderSrv.loadDashboard($routeParams.type, $routeParams.slug, $routeParams.uid).then(function(result) { if (result.meta.url) { const url = locationUtil.stripBaseFromUrl(result.meta.url); if (url !== $location.path()) { $location.path(url).replace(); } } if ($routeParams.keepRows) { result.meta.keepRows = true; } $scope.initDashboard(result, $scope); }); } } export class NewDashboardCtrl { /** @ngInject */ constructor($scope, $routeParams) { $scope.initDashboard( { meta: { canStar: false, canShare: false, isNew: true, folderId: Number($routeParams.folderId), }, dashboard: { title: 'New dashboard', panels: [ { type: 'add-panel', gridPos: { x: 0, y: 0, w: 12, h: 9 }, title: 'Panel Title', }, ], }, }, $scope ); } } coreModule.controller('LoadDashboardCtrl', LoadDashboardCtrl); coreModule.controller('NewDashboardCtrl', NewDashboardCtrl);