module.tsx 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. import { ReactPanelPlugin, getStatsCalculators, PanelModel } from '@grafana/ui';
  2. import { SingleStatOptions, defaults, SingleStatBaseOptions } from './types';
  3. import { SingleStatPanel } from './SingleStatPanel';
  4. import cloneDeep from 'lodash/cloneDeep';
  5. import { SingleStatEditor } from './SingleStatEditor';
  6. const optionsToKeep = ['valueOptions', 'stat', 'maxValue', 'maxValue', 'thresholds', 'valueMappings'];
  7. export const singleStatBaseOptionsCheck = (
  8. options: Partial<SingleStatBaseOptions>,
  9. prevPluginId: string,
  10. prevOptions: any
  11. ) => {
  12. optionsToKeep.forEach(v => {
  13. if (prevOptions.hasOwnProperty(v)) {
  14. options[v] = cloneDeep(prevOptions.display);
  15. }
  16. });
  17. return options;
  18. };
  19. export const singleStatMigrationCheck = (panel: PanelModel<SingleStatOptions>) => {
  20. const options = panel.options;
  21. if (options.valueOptions) {
  22. // 6.1 renamed some stats, This makes sure they are up to date
  23. // avg -> mean, current -> last, total -> sum
  24. const { valueOptions } = options;
  25. if (valueOptions && valueOptions.stat) {
  26. valueOptions.stat = getStatsCalculators([valueOptions.stat]).map(s => s.id)[0];
  27. }
  28. }
  29. return options;
  30. };
  31. export const reactPanel = new ReactPanelPlugin<SingleStatOptions>(SingleStatPanel)
  32. .setDefaults(defaults)
  33. .setEditor(SingleStatEditor)
  34. .setPanelChangeHandler(singleStatMigrationCheck)
  35. .setMigrationHandler(singleStatMigrationCheck);