mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
30 lines
975 B
TypeScript
30 lines
975 B
TypeScript
import { FC, ReactElement, useEffect, useState } from 'react';
|
|
|
|
import { PanelMenuItem } from '@grafana/data';
|
|
import { getPanelStateForModel } from 'app/features/panel/state/selectors';
|
|
import { useSelector } from 'app/types';
|
|
|
|
import { DashboardModel, PanelModel } from '../../state';
|
|
import { getPanelMenu } from '../../utils/getPanelMenu';
|
|
|
|
interface PanelHeaderMenuProviderApi {
|
|
items: PanelMenuItem[];
|
|
}
|
|
|
|
interface Props {
|
|
panel: PanelModel;
|
|
dashboard: DashboardModel;
|
|
children: (props: PanelHeaderMenuProviderApi) => ReactElement;
|
|
}
|
|
|
|
export const PanelHeaderMenuProvider: FC<Props> = ({ panel, dashboard, children }) => {
|
|
const [items, setItems] = useState<PanelMenuItem[]>([]);
|
|
const angularComponent = useSelector((state) => getPanelStateForModel(state, panel)?.angularComponent);
|
|
|
|
useEffect(() => {
|
|
setItems(getPanelMenu(dashboard, panel, angularComponent));
|
|
}, [dashboard, panel, angularComponent, setItems]);
|
|
|
|
return children({ items });
|
|
};
|