Submit
Path:
~
/
/
usr
/
share
/
grafana
/
public
/
app
/
features
/
dashboard
/
services
/
File Content:
DashboardSrv.ts
import { lastValueFrom } from 'rxjs'; import { AppEvents } from '@grafana/data'; import { BackendSrvRequest } from '@grafana/runtime'; import { Dashboard } from '@grafana/schema'; import { appEvents } from 'app/core/app_events'; import { t } from 'app/core/internationalization'; import { getBackendSrv } from 'app/core/services/backend_srv'; import { saveDashboard } from 'app/features/manage-dashboards/state/actions'; import { DashboardMeta } from 'app/types'; import { RemovePanelEvent } from '../../../types/events'; import { DashboardModel } from '../state/DashboardModel'; import { removePanel } from '../utils/panel'; export interface SaveDashboardOptions { /** The complete dashboard model. If `dashboard.id` is not set a new dashboard will be created. */ dashboard: DashboardModel; /** Set a commit message for the version history. */ message?: string; /** The UID of the folder to save the dashboard in. Overrides `folderId`. */ folderUid?: string; /** Set to `true` if you want to overwrite existing dashboard with newer version, * same dashboard title in folder or same dashboard uid. */ overwrite?: boolean; /** Set the dashboard refresh interval. * If this is lower than the minimum refresh interval, Grafana will ignore it and will enforce the minimum refresh interval. */ refresh?: string; } interface SaveDashboardResponse { id: number; slug: string; status: string; uid: string; url: string; version: number; } export class DashboardSrv { dashboard?: DashboardModel; constructor() { appEvents.subscribe(RemovePanelEvent, (e) => this.onRemovePanel(e.payload)); } create(dashboard: Dashboard, meta: DashboardMeta) { return new DashboardModel(dashboard, meta); } setCurrent(dashboard: DashboardModel | undefined) { this.dashboard = dashboard; } getCurrent(): DashboardModel | undefined { return this.dashboard; } onRemovePanel = (panelId: number) => { const dashboard = this.getCurrent(); if (dashboard) { removePanel(dashboard, dashboard.getPanelById(panelId)!, true); } }; saveJSONDashboard(json: string) { const parsedJson = JSON.parse(json); return saveDashboard({ dashboard: parsedJson, folderUid: this.dashboard?.meta.folderUid || parsedJson.folderUid, }); } saveDashboard( data: SaveDashboardOptions, requestOptions?: Pick<BackendSrvRequest, 'showErrorAlert' | 'showSuccessAlert'> ) { return lastValueFrom( getBackendSrv().fetch<SaveDashboardResponse>({ url: '/api/dashboards/db/', method: 'POST', data: { ...data, dashboard: data.dashboard.getSaveModelClone(), }, ...requestOptions, }) ); } starDashboard(dashboardUid: string, isStarred: boolean) { const backendSrv = getBackendSrv(); const request = { showSuccessAlert: false, url: '/api/user/stars/dashboard/uid/' + dashboardUid, method: isStarred ? 'DELETE' : 'POST', }; return backendSrv.request(request).then(() => { const newIsStarred = !isStarred; if (this.dashboard?.uid === dashboardUid) { this.dashboard.meta.isStarred = newIsStarred; } const message = newIsStarred ? t('notifications.starred-dashboard', 'Dashboard starred') : t('notifications.unstarred-dashboard', 'Dashboard unstarred'); appEvents.emit(AppEvents.alertSuccess, [message]); return newIsStarred; }); } } // // Code below is to export the service to React components // let singletonInstance: DashboardSrv; export function setDashboardSrv(instance: DashboardSrv) { singletonInstance = instance; } export function getDashboardSrv(): DashboardSrv { if (!singletonInstance) { singletonInstance = new DashboardSrv(); } return singletonInstance; }
Edit
Rename
Chmod
Delete
FILE
FOLDER
INFO
Name
Size
Permission
Action
DashboardLoaderSrv.ts
6991 bytes
0644
DashboardSrv.ts
3848 bytes
0644
SnapshotSrv.ts
4743 bytes
0644
TimeSrv.test.ts
11974 bytes
0644
TimeSrv.ts
12414 bytes
0644
N4ST4R_ID | Naxtarrr