module.tsx 1.4 KB

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