grafana/public/app/features/plugins/admin/components/GetStartedWithPlugin/GetStartedWithDataSource.tsx

37 lines
1002 B
TypeScript
Raw Normal View History

import React, { useCallback } from 'react';
import { DataSourcePluginMeta } from '@grafana/data';
import { Button } from '@grafana/ui';
import { useDataSourcesRoutes, addDataSource } from 'app/features/datasources/state';
import { useDispatch } from 'app/types';
import { isDataSourceEditor } from '../../permissions';
import { CatalogPlugin } from '../../types';
type Props = {
plugin: CatalogPlugin;
};
export function GetStartedWithDataSource({ plugin }: Props): React.ReactElement | null {
const dispatch = useDispatch();
const dataSourcesRoutes = useDataSourcesRoutes();
const onAddDataSource = useCallback(() => {
const meta = {
name: plugin.name,
id: plugin.id,
} as DataSourcePluginMeta;
dispatch(addDataSource(meta, dataSourcesRoutes.Edit));
}, [dispatch, plugin, dataSourcesRoutes]);
if (!isDataSourceEditor()) {
return null;
}
return (
<Button variant="primary" onClick={onAddDataSource}>
Add new data source
</Button>
);
}