import { DataSourceInstanceSettings, DataSourcePluginMeta, PluginType } from '@grafana/data'; import { ExpressionQuery, ExpressionQueryType } from './types'; import { ExpressionQueryEditor } from './ExpressionQueryEditor'; import { DataSourceWithBackend } from '@grafana/runtime'; /** * This is a singleton instance that just pretends to be a DataSource */ export class ExpressionDatasourceApi extends DataSourceWithBackend { constructor(instanceSettings: DataSourceInstanceSettings) { super(instanceSettings); } getCollapsedText(query: ExpressionQuery) { return `Expression: ${query.type}`; } newQuery(query?: Partial): ExpressionQuery { return { refId: '--', // Replaced with query type: query?.type ?? ExpressionQueryType.math, datasource: ExpressionDatasourceID, conditions: query?.conditions ?? undefined, }; } } // MATCHES the constant in DataSourceWithBackend export const ExpressionDatasourceID = '__expr__'; export const ExpressionDatasourceUID = '-100'; export const instanceSettings: DataSourceInstanceSettings = { id: -100, uid: ExpressionDatasourceUID, name: ExpressionDatasourceID, type: 'grafana-expression', meta: { baseUrl: '', module: '', type: PluginType.datasource, name: ExpressionDatasourceID, id: ExpressionDatasourceID, info: { author: { name: 'Grafana Labs', }, logos: { small: 'public/img/icn-datasource.svg', large: 'public/img/icn-datasource.svg', }, description: 'Adds expression support to Grafana', screenshots: [], links: [], updated: '', version: '', }, }, jsonData: {}, }; export const dataSource = new ExpressionDatasourceApi(instanceSettings); dataSource.meta = { id: ExpressionDatasourceID, info: { logos: { small: 'public/img/icn-datasource.svg', large: 'public/img/icn-datasource.svg', }, }, } as DataSourcePluginMeta; dataSource.components = { QueryEditor: ExpressionQueryEditor, };