-
Notifications
You must be signed in to change notification settings - Fork 495
Develop panel plugin
We have created a candlestick1
panel in previous doc, in this doc, let's see some key points in it.
First open index.ts
in DATAV_ROOT/ui/src/views/dashboard/plugins/external/panel/candlestick1
, you shoud see below content:
import { PanelPluginComponents } from "types/plugins/plugin";
import PanelComponent, { mockDataForTestDataDs } from "./Panel";
import PanelEditor from "./Editor";
import OverrideEditor, { OverrideRules, getOverrideTargets } from "./OverrideEditor";
const panelComponents: PanelPluginComponents = {
panel: PanelComponent,
editor: PanelEditor,
overrideEditor: OverrideEditor,
overrideRules: OverrideRules,
getOverrideTargets: getOverrideTargets,
mockDataForTestDataDs: mockDataForTestDataDs
}
export default panelComponents
This file export all the api of candlestick1
plugin that Datav requires, including:
-
panel
: the main panel component, used for render this panel -
editor
: when you open the panel editor, the options pane in the right is rendered with this
data:image/s3,"s3://crabby-images/e050f/e050f0d6d4ffb79239e775e8e64a62b26dc25e1e" alt="image"
As show above, this options editor is rendered by our editor
component, but you should notice that first three sections (Basic Setting
, Built-in plugins
, External plugins
) are common settings, they are not defined in each plugins but in ui/src/views/dashboard/edit-panel/PanelSettings.tsx
.
-
overrideEditor
: This defines the overrides items in the overrides editor for panel
data:image/s3,"s3://crabby-images/9e673/9e6734bf1d4864e0fd74c374e715b17f019ec67e" alt=""
The override editor skeleton is defined in ``ui/src/views/dashboard/edit-panel/PanelOverrides.tsx`
-
overrideRules
: defines the overrides rule names in the overrides editor for panel
data:image/s3,"s3://crabby-images/ade2c/ade2c15000345c2f8215e739f0fc68c2a3042a81" alt=""
-
getOverrideTargets
: defines the overrides target names in the overrides editor for panel
data:image/s3,"s3://crabby-images/82797/827976344f68952f4da87a1e4d1a7340dc39071e" alt=""
-
mockDataForTestDataDs
: provide mock data for TestData datasource, in most cases this should be SeriesData format, including ourcandlestick1
panel
data:image/s3,"s3://crabby-images/33d30/33d304f005952931c4b393822d40e38584579b05" alt=""
Sometimes, change an option can not trigger the chart library which panel uses to re-render, so we need a way to rebuild the panel and chart library :
dispatch(PanelForceRebuildEvent + panel.id)
Datav has provide a lot of components for you to use in your own plugins, such as ThresholdEditor, some of them are placed in ui/src/views/dashboard/plugins/components
, and others are defined at ui/src/components
, you can search built-in panels for detail usage.
data:image/s3,"s3://crabby-images/9d7d9/9d7d9c0edb1a14df8d67d1e9e4207bb9a4468ebf" alt="image"
These components can also be used in OverrideEdtiro.