import coreModule from 'app/core/core_module'; import { DashboardModel } from './dashboard_model'; export class DashboardSrv { dash: any; /** @ngInject */ constructor(private backendSrv, private $rootScope, private $location) {} create(dashboard, meta) { return new DashboardModel(dashboard, meta); } setCurrent(dashboard) { this.dash = dashboard; } getCurrent() { return this.dash; } handleSaveDashboardError(clone, err) { if (err.data && err.data.status === 'version-mismatch') { err.isHandled = true; this.$rootScope.appEvent('confirm-modal', { title: 'Conflict', text: 'Someone else has updated this dashboard.', text2: 'Would you still like to save this dashboard?', yesText: 'Save & Overwrite', icon: 'fa-warning', onConfirm: () => { this.save(clone, { overwrite: true }); }, }); } if (err.data && err.data.status === 'name-exists') { err.isHandled = true; this.$rootScope.appEvent('confirm-modal', { title: 'Conflict', text: 'Dashboard with the same name exists.', text2: 'Would you still like to save this dashboard?', yesText: 'Save & Overwrite', icon: 'fa-warning', onConfirm: () => { this.save(clone, { overwrite: true }); }, }); } if (err.data && err.data.status === 'plugin-dashboard') { err.isHandled = true; this.$rootScope.appEvent('confirm-modal', { title: 'Plugin Dashboard', text: err.data.message, text2: 'Your changes will be lost when you update the plugin. Use Save As to create custom version.', yesText: 'Overwrite', icon: 'fa-warning', altActionText: 'Save As', onAltAction: () => { this.showSaveAsModal(); }, onConfirm: () => { this.save(clone, { overwrite: true }); }, }); } } postSave(clone, data) { this.dash.version = data.version; var dashboardUrl = '/dashboard/db/' + data.slug; if (dashboardUrl !== this.$location.path()) { this.$location.url(dashboardUrl); } this.$rootScope.appEvent('dashboard-saved', this.dash); this.$rootScope.appEvent('alert-success', ['Dashboard saved']); } save(clone, options) { options = options || {}; options.folderId = this.dash.meta.folderId; return this.backendSrv .saveDashboard(clone, options) .then(this.postSave.bind(this, clone)) .catch(this.handleSaveDashboardError.bind(this, clone)); } saveDashboard(options, clone) { if (clone) { this.setCurrent(this.create(clone, this.dash.meta)); } if (!this.dash.meta.canSave && options.makeEditable !== true) { return Promise.resolve(); } if (this.dash.title === 'New dashboard') { return this.showSaveAsModal(); } if (this.dash.version > 0) { return this.showSaveModal(); } return this.save(this.dash.getSaveModelClone(), options); } showSaveAsModal() { this.$rootScope.appEvent('show-modal', { templateHtml: '', modalClass: 'modal--narrow', }); } showSaveModal() { this.$rootScope.appEvent('show-modal', { templateHtml: '', modalClass: 'modal--narrow', }); } starDashboard(dashboardId, isStarred) { let promise; if (isStarred) { promise = this.backendSrv.delete('/api/user/stars/dashboard/' + dashboardId).then(() => { return false; }); } else { promise = this.backendSrv.post('/api/user/stars/dashboard/' + dashboardId).then(() => { return true; }); } return promise.then(res => { if (this.dash && this.dash.id === dashboardId) { this.dash.meta.isStarred = res; } return res; }); } } coreModule.service('dashboardSrv', DashboardSrv);