All files / src/utils/playbook/options nrDashboard.ts

0% Statements 0/12
0% Branches 0/6
0% Functions 0/3
0% Lines 0/11

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44                                                                                       
import { Task } from "../../../types/index.ts";
import { getCurrentAsset } from "../getCurrentAsset.ts";
import { Key, KeyType } from "../key.ts";
 
export const nrDashboard = (key: KeyType, task: Task): any[] => {
  const options = getCurrentAsset(task, undefined, undefined, {
    idValue: "dashboard_guid",
    labelValue: "dashboard_name",
  });
  switch (key) {
    case Key.DASHBOARD_GUID:
      return options;
    case Key.PAGE_GUID:
      return getCurrentAsset(
        task,
        Key.DASHBOARD_GUID,
        "dashboard_guid",
        undefined,
        "pages",
      ).map((e: any) => {
        return {
          id: e.page_guid,
          label: e.page_name,
        };
      });
    case Key.WIDGET_NRQL_EXPRESSION:
      return getCurrentAsset(
        task,
        Key.DASHBOARD_GUID,
        "dashboard_guid",
        undefined,
        "pages",
      )?.[0]?.widgets?.map((e: any) => {
        return {
          id: e.widget_id,
          label: e.widget_title || e.widget_nrql_expression,
          widget: e,
        };
      });
    default:
      return [];
  }
};