@c8y/ngx-components 1018.503.145 → 1018.503.151

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/context-dashboard/context-dashboard.model.d.ts +1 -0
  2. package/context-dashboard/report-dashboard/report-dashboard-list.component.d.ts +29 -0
  3. package/core/common/ApplicationOptions.d.ts +1 -1
  4. package/core/docs/docs.service.d.ts +1 -1
  5. package/core/docs/help-and-support-outlet/help-and-support-outlet.component.d.ts +5 -1
  6. package/core/docs/legal-notices-outlet/legal-notices-outlet.component.d.ts +5 -1
  7. package/core/docs/support-outlet/support-outlet.component.d.ts +5 -1
  8. package/core/select/select.component.d.ts +1 -0
  9. package/core/shared/core.model.d.ts +5 -1
  10. package/ecosystem/application-plugins/application-plugins.component.d.ts +5 -0
  11. package/ecosystem/packages/package-details/package-details.component.d.ts +3 -2
  12. package/ecosystem/shared/ecosystem.model.d.ts +4 -0
  13. package/esm2020/context-dashboard/context-dashboard.model.mjs +3 -2
  14. package/esm2020/context-dashboard/report-dashboard/report-dashboard-list.component.mjs +4 -3
  15. package/esm2020/core/common/ApplicationOptions.mjs +1 -1
  16. package/esm2020/core/docs/defaults.items.mjs +4 -4
  17. package/esm2020/core/docs/docs.service.mjs +2 -2
  18. package/esm2020/core/docs/support-outlet/support-outlet.component.mjs +3 -3
  19. package/esm2020/core/i18n/translate.service.mjs +7 -5
  20. package/esm2020/core/select/select.component.mjs +10 -11
  21. package/esm2020/core/shared/core.model.mjs +6 -2
  22. package/esm2020/device-list/add-smart-group.component.mjs +3 -3
  23. package/esm2020/ecosystem/application-plugins/application-plugins.component.mjs +40 -39
  24. package/esm2020/ecosystem/application-plugins/plugin-list.component.mjs +9 -12
  25. package/esm2020/ecosystem/packages/package-details/package-details.component.mjs +11 -6
  26. package/esm2020/ecosystem/shared/ecosystem.model.mjs +7 -3
  27. package/esm2020/widgets/implementations/cockpit-welcome/welcome.component.mjs +2 -2
  28. package/fesm2015/c8y-ngx-components-context-dashboard.mjs +5 -3
  29. package/fesm2015/c8y-ngx-components-context-dashboard.mjs.map +1 -1
  30. package/fesm2015/c8y-ngx-components-device-list.mjs +2 -2
  31. package/fesm2015/c8y-ngx-components-device-list.mjs.map +1 -1
  32. package/fesm2015/c8y-ngx-components-ecosystem-application-plugins.mjs +36 -39
  33. package/fesm2015/c8y-ngx-components-ecosystem-application-plugins.mjs.map +1 -1
  34. package/fesm2015/c8y-ngx-components-ecosystem-shared.mjs +6 -2
  35. package/fesm2015/c8y-ngx-components-ecosystem-shared.mjs.map +1 -1
  36. package/fesm2015/c8y-ngx-components-ecosystem.mjs +44 -42
  37. package/fesm2015/c8y-ngx-components-ecosystem.mjs.map +1 -1
  38. package/fesm2015/c8y-ngx-components-widgets-implementations-cockpit-welcome.mjs +1 -1
  39. package/fesm2015/c8y-ngx-components-widgets-implementations-cockpit-welcome.mjs.map +1 -1
  40. package/fesm2015/c8y-ngx-components.mjs +26 -21
  41. package/fesm2015/c8y-ngx-components.mjs.map +1 -1
  42. package/fesm2020/c8y-ngx-components-context-dashboard.mjs +5 -3
  43. package/fesm2020/c8y-ngx-components-context-dashboard.mjs.map +1 -1
  44. package/fesm2020/c8y-ngx-components-device-list.mjs +2 -2
  45. package/fesm2020/c8y-ngx-components-device-list.mjs.map +1 -1
  46. package/fesm2020/c8y-ngx-components-ecosystem-application-plugins.mjs +47 -49
  47. package/fesm2020/c8y-ngx-components-ecosystem-application-plugins.mjs.map +1 -1
  48. package/fesm2020/c8y-ngx-components-ecosystem-shared.mjs +6 -2
  49. package/fesm2020/c8y-ngx-components-ecosystem-shared.mjs.map +1 -1
  50. package/fesm2020/c8y-ngx-components-ecosystem.mjs +55 -52
  51. package/fesm2020/c8y-ngx-components-ecosystem.mjs.map +1 -1
  52. package/fesm2020/c8y-ngx-components-widgets-implementations-cockpit-welcome.mjs +1 -1
  53. package/fesm2020/c8y-ngx-components-widgets-implementations-cockpit-welcome.mjs.map +1 -1
  54. package/fesm2020/c8y-ngx-components.mjs +26 -21
  55. package/fesm2020/c8y-ngx-components.mjs.map +1 -1
  56. package/locales/de.po +8 -290
  57. package/locales/es.po +0 -282
  58. package/locales/fr.po +16 -298
  59. package/locales/ja_JP.po +18 -296
  60. package/locales/ko.po +18 -294
  61. package/locales/locales.pot +0 -282
  62. package/locales/nl.po +0 -282
  63. package/locales/pl.po +0 -282
  64. package/locales/pt_BR.po +0 -282
  65. package/locales/zh_CN.po +12 -293
  66. package/locales/zh_TW.po +12 -293
  67. package/package.json +1 -1
@@ -201,6 +201,7 @@ export declare const PRODUCT_EXPERIENCE: {
201
201
  DELETE: string;
202
202
  LOAD: string;
203
203
  CREATE: string;
204
+ ADD_REPORT: string;
204
205
  };
205
206
  };
206
207
  };
@@ -17,6 +17,35 @@ export declare class ReportDashboardListComponent implements OnInit {
17
17
  private reportDashboardService;
18
18
  private permissions;
19
19
  private gainsightService;
20
+ PRODUCT_EXPERIENCE: {
21
+ DASHBOARD: {
22
+ EVENTS: {
23
+ DASHBOARDS: string;
24
+ REPORTS: string;
25
+ };
26
+ COMPONENTS: {
27
+ DASHBOARD_VIEW: string;
28
+ DASHBOARD_AVAILABILITY: string;
29
+ REPORTS_LIST: string;
30
+ ADD_REPORT: string;
31
+ ADD_DASHBOARD: string;
32
+ DELETE_DASHBOARD: string;
33
+ };
34
+ CONTEXT: {
35
+ REPORT: string;
36
+ DEVICE: string;
37
+ ASSET: string;
38
+ GROUP: string;
39
+ };
40
+ ACTIONS: {
41
+ APPLY_GLOBAL_ROLES_CHANGES: string;
42
+ DELETE: string;
43
+ LOAD: string;
44
+ CREATE: string;
45
+ ADD_REPORT: string;
46
+ };
47
+ };
48
+ };
20
49
  filter: FilterInputComponent;
21
50
  textFilter$: BehaviorSubject<string>;
22
51
  reload$: BehaviorSubject<void>;
@@ -156,7 +156,7 @@ export declare class ApplicationOptions {
156
156
  /**
157
157
  * Allows to enable or disable context help, or to override the default base URL used to load its contents.
158
158
  * By default, the context help uses the same base URL as defined in the `docsBaseUrl` option
159
- * (if this option is undefined, then the following value will be used: `https://www.cumulocity.com`).
159
+ * (if this option is undefined, then the following value will be used: `https://cumulocity.com/guides/{{version}}`).
160
160
  * Alternatively, if a string is provided here, it'll be used as the base URL
161
161
  * and any `{{ version }}` placeholder will be replaced with the relevant docs version.
162
162
  */
@@ -14,7 +14,7 @@ export declare class DocsService extends ExtensionPointWithoutStateForPlugins<Do
14
14
  /**
15
15
  * Default documentation URL.
16
16
  */
17
- readonly DEFAULT_DOCS_BASE_URL = "https://www.cumulocity.com";
17
+ readonly DEFAULT_DOCS_BASE_URL = "https://cumulocity.com";
18
18
  constructor(options: OptionsService, app: AppStateService, rootInjector: Injector, router: Router, plugins: PluginsResolveService);
19
19
  getBaseUrl(uiVersion?: string | {
20
20
  ngx: string;
@@ -26,7 +26,11 @@ export declare class HelpAndSupportOutletComponent {
26
26
  COMPONENTS: {
27
27
  RIGHT_DRAWER_COMPONENT: string;
28
28
  };
29
- ACTIONS: {};
29
+ ACTIONS: {
30
+ ACTIVATE_SUPPORT_ACCESS: string;
31
+ DEACTIVATE_SUPPORT_ACCESS: string;
32
+ OPEN_SUPPORT_LINK: string;
33
+ };
30
34
  RESULTS: {};
31
35
  };
32
36
  };
@@ -24,7 +24,11 @@ export declare class LegalNoticesOutletComponent {
24
24
  COMPONENTS: {
25
25
  RIGHT_DRAWER_COMPONENT: string;
26
26
  };
27
- ACTIONS: {};
27
+ ACTIONS: {
28
+ ACTIVATE_SUPPORT_ACCESS: string;
29
+ DEACTIVATE_SUPPORT_ACCESS: string;
30
+ OPEN_SUPPORT_LINK: string;
31
+ };
28
32
  RESULTS: {};
29
33
  };
30
34
  };
@@ -42,7 +42,11 @@ export declare class SupportOutletComponent implements OnInit {
42
42
  COMPONENTS: {
43
43
  RIGHT_DRAWER_COMPONENT: string;
44
44
  };
45
- ACTIONS: {};
45
+ ACTIONS: {
46
+ ACTIVATE_SUPPORT_ACCESS: string;
47
+ DEACTIVATE_SUPPORT_ACCESS: string;
48
+ OPEN_SUPPORT_LINK: string;
49
+ };
46
50
  RESULTS: {};
47
51
  };
48
52
  };
@@ -21,6 +21,7 @@ export declare class SelectComponent implements OnChanges, OnInit {
21
21
  liChildren: any;
22
22
  textFilter: string;
23
23
  labelText: string;
24
+ truncatedLabelText: string;
24
25
  isOpen: boolean;
25
26
  filteredItems: Item[];
26
27
  searchFilter: any;
@@ -16,7 +16,11 @@ export declare const PRODUCT_EXPERIENCE: {
16
16
  COMPONENTS: {
17
17
  RIGHT_DRAWER_COMPONENT: string;
18
18
  };
19
- ACTIONS: {};
19
+ ACTIONS: {
20
+ ACTIVATE_SUPPORT_ACCESS: string;
21
+ DEACTIVATE_SUPPORT_ACCESS: string;
22
+ OPEN_SUPPORT_LINK: string;
23
+ };
20
24
  RESULTS: {};
21
25
  };
22
26
  };
@@ -36,6 +36,7 @@ export declare class ApplicationPluginsComponent implements OnInit, OnDestroy {
36
36
  PACKAGE_VERSIONS: string;
37
37
  UPDATE_PLUGIN_OF_APP: string;
38
38
  LIST_FILTERS: string;
39
+ PACKAGE_DETAILS: string;
39
40
  };
40
41
  ACTIONS: {
41
42
  AVAILABILITY_CHANGE: string;
@@ -48,6 +49,7 @@ export declare class ApplicationPluginsComponent implements OnInit, OnDestroy {
48
49
  EDIT: string;
49
50
  INSTALL_PLUGIN: string;
50
51
  INSTALL_PLUGINS: string;
52
+ UNINSTALL_PLUGIN: string;
51
53
  SELECT_VERSION: string;
52
54
  SET_AS_LATEST: string;
53
55
  UPDATE_AVAILABLE: string;
@@ -55,6 +57,8 @@ export declare class ApplicationPluginsComponent implements OnInit, OnDestroy {
55
57
  SET_FILTER_TERM: string;
56
58
  SET_PREDEFINED_FILTERS: string;
57
59
  RESET_FILTER: string;
60
+ INSTALL_PLUGINS_INITIATED: string;
61
+ DEPLOY_APPLICATION_INITIATED: string;
58
62
  };
59
63
  RESULTS: {
60
64
  DEPLOYED: string;
@@ -113,6 +117,7 @@ export declare class ApplicationPluginsComponent implements OnInit, OnDestroy {
113
117
  private getInstalledPlugins;
114
118
  private extractDetails;
115
119
  private getStringMatchingRegex;
120
+ private triggerPluginEvent;
116
121
  static ɵfac: i0.ɵɵFactoryDeclaration<ApplicationPluginsComponent, never>;
117
122
  static ɵcmp: i0.ɵɵComponentDeclaration<ApplicationPluginsComponent, "c8y-app-plugins", never, { "appId": "appId"; }, {}, never, never, false, never>;
118
123
  }
@@ -1,7 +1,7 @@
1
1
  import { OnInit } from '@angular/core';
2
2
  import { ActivatedRoute } from '@angular/router';
3
3
  import { ApplicationAvailability, FetchClient, IApplication } from '@c8y/client';
4
- import { ApplicationPlugin, AppStateService, ContextRouteService, PackageType, PluginsService, PropertiesListItem, WizardModalService } from '@c8y/ngx-components';
4
+ import { ApplicationPlugin, AppStateService, ContextRouteService, GainsightService, PackageType, PluginsService, PropertiesListItem, WizardModalService } from '@c8y/ngx-components';
5
5
  import { BehaviorSubject } from 'rxjs';
6
6
  import { ApplicationState, EcosystemService, PackageAvailabilityService } from '@c8y/ngx-components/ecosystem/shared';
7
7
  import * as i0 from "@angular/core";
@@ -15,6 +15,7 @@ export declare class PackageDetailsComponent implements OnInit {
15
15
  private packageAvailabilityService;
16
16
  private ui;
17
17
  private pluginService;
18
+ private gainsightService;
18
19
  markdown: string;
19
20
  baseUrl: string;
20
21
  package: IApplication;
@@ -47,7 +48,7 @@ export declare class PackageDetailsComponent implements OnInit {
47
48
  readonly packageProperties: PropertiesListItem[];
48
49
  private readonly headers;
49
50
  private NOT_FOUND_ERROR_CODE;
50
- constructor(activatedRoute: ActivatedRoute, client: FetchClient, wizardModalService: WizardModalService, ecosystemService: EcosystemService, contextRouteService: ContextRouteService, pluginsService: PluginsService, packageAvailabilityService: PackageAvailabilityService, ui: AppStateService, pluginService: PluginsService);
51
+ constructor(activatedRoute: ActivatedRoute, client: FetchClient, wizardModalService: WizardModalService, ecosystemService: EcosystemService, contextRouteService: ContextRouteService, pluginsService: PluginsService, packageAvailabilityService: PackageAvailabilityService, ui: AppStateService, pluginService: PluginsService, gainsightService: GainsightService);
51
52
  ngOnInit(): Promise<void>;
52
53
  deploy(): void;
53
54
  togglePackageAvailability(pckg: IApplication, newAvailability: ApplicationAvailability): Promise<void>;
@@ -44,6 +44,7 @@ export declare const PRODUCT_EXPERIENCE: {
44
44
  PACKAGE_VERSIONS: string;
45
45
  UPDATE_PLUGIN_OF_APP: string;
46
46
  LIST_FILTERS: string;
47
+ PACKAGE_DETAILS: string;
47
48
  };
48
49
  ACTIONS: {
49
50
  AVAILABILITY_CHANGE: string;
@@ -56,6 +57,7 @@ export declare const PRODUCT_EXPERIENCE: {
56
57
  EDIT: string;
57
58
  INSTALL_PLUGIN: string;
58
59
  INSTALL_PLUGINS: string;
60
+ UNINSTALL_PLUGIN: string;
59
61
  SELECT_VERSION: string;
60
62
  SET_AS_LATEST: string;
61
63
  UPDATE_AVAILABLE: string;
@@ -63,6 +65,8 @@ export declare const PRODUCT_EXPERIENCE: {
63
65
  SET_FILTER_TERM: string;
64
66
  SET_PREDEFINED_FILTERS: string;
65
67
  RESET_FILTER: string;
68
+ INSTALL_PLUGINS_INITIATED: string;
69
+ DEPLOY_APPLICATION_INITIATED: string;
66
70
  };
67
71
  RESULTS: {
68
72
  DEPLOYED: string;
@@ -113,8 +113,9 @@ export const PRODUCT_EXPERIENCE = {
113
113
  APPLY_GLOBAL_ROLES_CHANGES: 'applyGlobalRolesChanges',
114
114
  DELETE: 'delete',
115
115
  LOAD: 'load',
116
- CREATE: 'create'
116
+ CREATE: 'create',
117
+ ADD_REPORT: 'addReport'
117
118
  }
118
119
  }
119
120
  };
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-dashboard.model.js","sourceRoot":"","sources":["../../../context-dashboard/context-dashboard.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { InjectionToken } from '@angular/core';\nimport { IManagedObject } from '@c8y/client';\nimport {\n  Widget,\n  DynamicComponentDefinition,\n  Route,\n  gettext,\n  ViewContext,\n  WidgetDisplaySettings\n} from '@c8y/ngx-components';\n\nexport const CONTEXT_DASHBOARD_CONFIG = new InjectionToken<any>('ContextDashboardConfig');\n\nexport interface ContextDashboardConfig {\n  widgetFilter?: (component: DynamicComponentDefinition) => boolean;\n  allowFullscreen?: boolean;\n  routes?: Route[];\n}\n\nexport interface ContextWidgetConfig {\n  /**\n   * Settings that define how the default config component is\n   * displayed. They are static and will not be saved.\n   */\n  settings?: {\n    /**\n     * Avoids to show the widget in the \"add widget\" modal\n     */\n    noNewWidgets?: boolean;\n    ng1?: {\n      options: {\n        /**\n         * Set this to false, to hide the device/group selector\n         * @deprecated: This is currently only implemented in angularjs and will be exported to a separate component.\n         */\n        noDeviceTarget?: boolean;\n        /**\n         * Set this to false to only select devices\n         * @deprecated: This is currently only implemented in angularjs and will be exported to a separate component.\n         */\n        groupsSelectable?: boolean;\n      };\n      /**\n       * The context from the device selector.\n       */\n      context?: {\n        id?: string;\n        name?: string;\n      };\n    };\n    /**\n     * Additional settings passed to the configuration component.\n     */\n    [key: string]: any;\n  };\n\n  /**\n   * Settings that are injected in any displaying component.\n   */\n  displaySettings?: WidgetDisplaySettings;\n\n  /**\n   * Whatever should be added to the configuration when a widget is created.\n   */\n  config?: {\n    /**\n     * Any other information that should be stored here.\n     */\n    [key: string]: any;\n  };\n  /**\n   * The selected device or group (note: naming is inconsistent as group was added later\n   * but must stay for already implemented widgets)\n   */\n  device?: {\n    id?: string | number;\n    name?: string;\n    [key: string]: any;\n  };\n  /**\n   * Any other information that should be stored here.\n   */\n  [key: string]: any;\n}\n\nexport interface ContextDashboardManagedObject extends IManagedObject {\n  c8y_Dashboard?: ContextDashboard;\n  name?: string;\n}\n\nexport interface ContextDashboard {\n  icon?: string;\n  name?: string;\n  priority?: number;\n  deviceType?: boolean;\n  deviceTypeValue?: string;\n  isFrozen?: boolean;\n  classes?: { [key: string]: boolean };\n  widgetClasses?: { [key: string]: boolean };\n  widgetMargin?: number;\n  translateWidgetTitle?: boolean;\n  global?: boolean;\n  /**\n   * The amount of columns on that dashboard.\n   * Can be freely chosen, but product uses either 12 or 24.\n   */\n  columns?: number;\n  children?: {\n    [id: string]: Widget;\n  };\n  globalRolesIds?: DashboardGlobalRoles;\n  c8y_IsNavigatorNode?: object;\n  description?: string;\n}\n\nexport enum ContextDashboardType {\n  Device = 'device',\n  DeviceType = 'type',\n  Group = 'group',\n  Named = 'name',\n  Report = 'report'\n}\n\nexport const WIDGET_HEADER_CLASSES = [\n  {\n    label: gettext('Regular`style`'),\n    class: 'panel-title-regular',\n    description: gettext('The widget has no border between header and content.')\n  },\n  {\n    label: gettext('Border`style`'),\n    class: 'panel-title-border',\n    description: gettext('The widget has a small separation border between header and content.')\n  },\n  {\n    label: gettext('Overlay`style`'),\n    class: 'panel-title-overlay',\n    description: gettext('The widget content overlays the header.')\n  },\n  {\n    label: gettext('Hidden`style`'),\n    class: 'panel-title-hidden',\n    description: gettext('The widget header is not shown.')\n  }\n];\n\nexport const WIDGET_CONTENT_CLASSES = [\n  {\n    label: gettext('Match dashboard`style`'),\n    class: 'panel-content-light',\n    description: gettext('The widget appearance matches the dashboard appearance.')\n  },\n  {\n    label: gettext('Light`style`'),\n    class: 'panel-content-white',\n    description: gettext('The widget has light appearance, that is, dark text on light background.')\n  },\n  {\n    label: gettext('Dark`style`'),\n    class: 'panel-content-dark',\n    description: gettext('The widget has dark appearance, that is, light text on dark background.')\n  },\n  {\n    label: gettext('Transparent`style`'),\n    class: 'panel-content-transparent',\n    description: gettext('The widget has no background.')\n  },\n  {\n    label: gettext('Branded`style`'),\n    class: 'panel-content-branded',\n    description: gettext('The widget is styled with the main brand color.')\n  }\n];\n\nexport const DASHBOARD_THEME_CLASSES = [\n  {\n    label: gettext('Match UI`theme`'),\n    class: 'dashboard-theme-light',\n    description: gettext('The dashboard appearance matches the UI appearance.')\n  },\n  {\n    label: gettext('Light`theme`'),\n    class: 'dashboard-theme-white',\n    description: gettext(\n      'The dashboard has light appearance, that is, dark text on light background.'\n    )\n  },\n  {\n    label: gettext('Dark`theme`'),\n    class: 'dashboard-theme-dark',\n    description: gettext(\n      'The dashboard has dark appearance, that is, light text on dark background.'\n    )\n  },\n  // {\n  //   label: gettext('Transparent`theme`'),\n  //   class: 'dashboard-theme-transparent',\n  //   description: gettext(\n  //     'The dashboard is styled with a transparent background and therefore is border-less.'\n  //   )\n  // },\n  {\n    label: gettext('Branded`theme`'),\n    class: 'dashboard-theme-branded',\n    description: gettext('The dashboard is styled using the brand palette.')\n  }\n];\n\nexport const STYLING_CLASS_PREFIXES = ['dashboard-theme-', 'panel-title-', 'panel-content-'];\n\nexport interface DashboardCopyClipboard {\n  dashboardId: string;\n  dashboard: ContextDashboard;\n  context: DashboardContext;\n}\n\nexport interface DashboardContext {\n  context: ViewContext;\n  contextData: Partial<IManagedObject>;\n}\n\nexport const ALL_GLOBAL_ROLES_SELECTED = 'all' as const;\nexport type DashboardGlobalRoles = number[] | typeof ALL_GLOBAL_ROLES_SELECTED;\n\nexport const PRODUCT_EXPERIENCE = {\n  DASHBOARD: {\n    EVENTS: {\n      DASHBOARDS: 'dashboards',\n      REPORTS: 'reports'\n    },\n    COMPONENTS: {\n      DASHBOARD_VIEW: 'context-dashboard',\n      DASHBOARD_AVAILABILITY: 'dashboard-availability',\n      REPORTS_LIST: 'report-dashboard-list',\n      ADD_REPORT: 'report-dashboard-list',\n      ADD_DASHBOARD: 'add-dashboard',\n      DELETE_DASHBOARD: 'context-dashboard'\n    },\n    CONTEXT: {\n      REPORT: 'report',\n      DEVICE: 'device',\n      ASSET: 'asset',\n      GROUP: 'group'\n    },\n    ACTIONS: {\n      APPLY_GLOBAL_ROLES_CHANGES: 'applyGlobalRolesChanges',\n      DELETE: 'delete',\n      LOAD: 'load',\n      CREATE: 'create'\n    }\n  }\n};\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-dashboard.model.js","sourceRoot":"","sources":["../../../context-dashboard/context-dashboard.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { InjectionToken } from '@angular/core';\nimport { IManagedObject } from '@c8y/client';\nimport {\n  Widget,\n  DynamicComponentDefinition,\n  Route,\n  gettext,\n  ViewContext,\n  WidgetDisplaySettings\n} from '@c8y/ngx-components';\n\nexport const CONTEXT_DASHBOARD_CONFIG = new InjectionToken<any>('ContextDashboardConfig');\n\nexport interface ContextDashboardConfig {\n  widgetFilter?: (component: DynamicComponentDefinition) => boolean;\n  allowFullscreen?: boolean;\n  routes?: Route[];\n}\n\nexport interface ContextWidgetConfig {\n  /**\n   * Settings that define how the default config component is\n   * displayed. They are static and will not be saved.\n   */\n  settings?: {\n    /**\n     * Avoids to show the widget in the \"add widget\" modal\n     */\n    noNewWidgets?: boolean;\n    ng1?: {\n      options: {\n        /**\n         * Set this to false, to hide the device/group selector\n         * @deprecated: This is currently only implemented in angularjs and will be exported to a separate component.\n         */\n        noDeviceTarget?: boolean;\n        /**\n         * Set this to false to only select devices\n         * @deprecated: This is currently only implemented in angularjs and will be exported to a separate component.\n         */\n        groupsSelectable?: boolean;\n      };\n      /**\n       * The context from the device selector.\n       */\n      context?: {\n        id?: string;\n        name?: string;\n      };\n    };\n    /**\n     * Additional settings passed to the configuration component.\n     */\n    [key: string]: any;\n  };\n\n  /**\n   * Settings that are injected in any displaying component.\n   */\n  displaySettings?: WidgetDisplaySettings;\n\n  /**\n   * Whatever should be added to the configuration when a widget is created.\n   */\n  config?: {\n    /**\n     * Any other information that should be stored here.\n     */\n    [key: string]: any;\n  };\n  /**\n   * The selected device or group (note: naming is inconsistent as group was added later\n   * but must stay for already implemented widgets)\n   */\n  device?: {\n    id?: string | number;\n    name?: string;\n    [key: string]: any;\n  };\n  /**\n   * Any other information that should be stored here.\n   */\n  [key: string]: any;\n}\n\nexport interface ContextDashboardManagedObject extends IManagedObject {\n  c8y_Dashboard?: ContextDashboard;\n  name?: string;\n}\n\nexport interface ContextDashboard {\n  icon?: string;\n  name?: string;\n  priority?: number;\n  deviceType?: boolean;\n  deviceTypeValue?: string;\n  isFrozen?: boolean;\n  classes?: { [key: string]: boolean };\n  widgetClasses?: { [key: string]: boolean };\n  widgetMargin?: number;\n  translateWidgetTitle?: boolean;\n  global?: boolean;\n  /**\n   * The amount of columns on that dashboard.\n   * Can be freely chosen, but product uses either 12 or 24.\n   */\n  columns?: number;\n  children?: {\n    [id: string]: Widget;\n  };\n  globalRolesIds?: DashboardGlobalRoles;\n  c8y_IsNavigatorNode?: object;\n  description?: string;\n}\n\nexport enum ContextDashboardType {\n  Device = 'device',\n  DeviceType = 'type',\n  Group = 'group',\n  Named = 'name',\n  Report = 'report'\n}\n\nexport const WIDGET_HEADER_CLASSES = [\n  {\n    label: gettext('Regular`style`'),\n    class: 'panel-title-regular',\n    description: gettext('The widget has no border between header and content.')\n  },\n  {\n    label: gettext('Border`style`'),\n    class: 'panel-title-border',\n    description: gettext('The widget has a small separation border between header and content.')\n  },\n  {\n    label: gettext('Overlay`style`'),\n    class: 'panel-title-overlay',\n    description: gettext('The widget content overlays the header.')\n  },\n  {\n    label: gettext('Hidden`style`'),\n    class: 'panel-title-hidden',\n    description: gettext('The widget header is not shown.')\n  }\n];\n\nexport const WIDGET_CONTENT_CLASSES = [\n  {\n    label: gettext('Match dashboard`style`'),\n    class: 'panel-content-light',\n    description: gettext('The widget appearance matches the dashboard appearance.')\n  },\n  {\n    label: gettext('Light`style`'),\n    class: 'panel-content-white',\n    description: gettext('The widget has light appearance, that is, dark text on light background.')\n  },\n  {\n    label: gettext('Dark`style`'),\n    class: 'panel-content-dark',\n    description: gettext('The widget has dark appearance, that is, light text on dark background.')\n  },\n  {\n    label: gettext('Transparent`style`'),\n    class: 'panel-content-transparent',\n    description: gettext('The widget has no background.')\n  },\n  {\n    label: gettext('Branded`style`'),\n    class: 'panel-content-branded',\n    description: gettext('The widget is styled with the main brand color.')\n  }\n];\n\nexport const DASHBOARD_THEME_CLASSES = [\n  {\n    label: gettext('Match UI`theme`'),\n    class: 'dashboard-theme-light',\n    description: gettext('The dashboard appearance matches the UI appearance.')\n  },\n  {\n    label: gettext('Light`theme`'),\n    class: 'dashboard-theme-white',\n    description: gettext(\n      'The dashboard has light appearance, that is, dark text on light background.'\n    )\n  },\n  {\n    label: gettext('Dark`theme`'),\n    class: 'dashboard-theme-dark',\n    description: gettext(\n      'The dashboard has dark appearance, that is, light text on dark background.'\n    )\n  },\n  // {\n  //   label: gettext('Transparent`theme`'),\n  //   class: 'dashboard-theme-transparent',\n  //   description: gettext(\n  //     'The dashboard is styled with a transparent background and therefore is border-less.'\n  //   )\n  // },\n  {\n    label: gettext('Branded`theme`'),\n    class: 'dashboard-theme-branded',\n    description: gettext('The dashboard is styled using the brand palette.')\n  }\n];\n\nexport const STYLING_CLASS_PREFIXES = ['dashboard-theme-', 'panel-title-', 'panel-content-'];\n\nexport interface DashboardCopyClipboard {\n  dashboardId: string;\n  dashboard: ContextDashboard;\n  context: DashboardContext;\n}\n\nexport interface DashboardContext {\n  context: ViewContext;\n  contextData: Partial<IManagedObject>;\n}\n\nexport const ALL_GLOBAL_ROLES_SELECTED = 'all' as const;\nexport type DashboardGlobalRoles = number[] | typeof ALL_GLOBAL_ROLES_SELECTED;\n\nexport const PRODUCT_EXPERIENCE = {\n  DASHBOARD: {\n    EVENTS: {\n      DASHBOARDS: 'dashboards',\n      REPORTS: 'reports'\n    },\n    COMPONENTS: {\n      DASHBOARD_VIEW: 'context-dashboard',\n      DASHBOARD_AVAILABILITY: 'dashboard-availability',\n      REPORTS_LIST: 'report-dashboard-list',\n      ADD_REPORT: 'report-dashboard-list',\n      ADD_DASHBOARD: 'add-dashboard',\n      DELETE_DASHBOARD: 'context-dashboard'\n    },\n    CONTEXT: {\n      REPORT: 'report',\n      DEVICE: 'device',\n      ASSET: 'asset',\n      GROUP: 'group'\n    },\n    ACTIONS: {\n      APPLY_GLOBAL_ROLES_CHANGES: 'applyGlobalRolesChanges',\n      DELETE: 'delete',\n      LOAD: 'load',\n      CREATE: 'create',\n      ADD_REPORT: 'addReport'\n    }\n  }\n};\n"]}
@@ -32,6 +32,7 @@ export class ReportDashboardListComponent {
32
32
  this.reportDashboardService = reportDashboardService;
33
33
  this.permissions = permissions;
34
34
  this.gainsightService = gainsightService;
35
+ this.PRODUCT_EXPERIENCE = PRODUCT_EXPERIENCE;
35
36
  this.textFilter$ = new BehaviorSubject('');
36
37
  this.reload$ = new BehaviorSubject(null);
37
38
  this.reloading = false;
@@ -144,12 +145,12 @@ export class ReportDashboardListComponent {
144
145
  }
145
146
  }
146
147
  ReportDashboardListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ReportDashboardListComponent, deps: [{ token: i1.InventoryService }, { token: i2.ContextDashboardService }, { token: i3.BsModalService }, { token: i4.TranslateService }, { token: i5.ModalService }, { token: i5.AlertService }, { token: i6.ReportDashboardService }, { token: i5.Permissions }, { token: i5.GainsightService }], target: i0.ɵɵFactoryTarget.Component });
147
- ReportDashboardListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ReportDashboardListComponent, selector: "c8y-report-dashboard-list", viewQueries: [{ propertyName: "filter", first: true, predicate: FilterInputComponent, descendants: true }], ngImport: i0, template: "<c8y-title>\n {{ 'Reports' | translate }}\n</c8y-title>\n\n<c8y-action-bar-item\n [placement]=\"'left'\"\n itemClass=\"navbar-form\"\n>\n <div class=\"input-group input-group-search\">\n <input\n class=\"form-control\"\n [attr.aria-label]=\"'Filter' | translate\"\n placeholder=\"{{ 'Filter\u2026' | translate }}\"\n type=\"search\"\n [ngModel]=\"textFilter$ | async\"\n (ngModelChange)=\"textFilter$.next($event)\"\n />\n <span class=\"input-group-addon\">\n <i\n c8yIcon=\"search\"\n *ngIf=\"(textFilter$ | async).length === 0\"\n ></i>\n <i\n class=\"text-muted\"\n c8yIcon=\"times\"\n *ngIf=\"(textFilter$ | async).length > 0\"\n (click)=\"textFilter$.next('')\"\n px-event=\"Clear filtering reports\"\n ></i>\n </span>\n </div>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add report' | translate }}\"\n type=\"button\"\n [attr.data-cy]=\"'reports-add-report-action-bar-button'\"\n (click)=\"add()\"\n [disabled]=\"!canAddReport\"\n >\n <i c8yIcon=\"plus-circle\"></i>\n {{ 'Add report' | translate }}\n </button>\n <button\n class=\"btn btn-dot m-r-16\"\n aria-label=\"{{ 'Info' | translate }}\"\n popover=\"{{ 'You don\\'t have permission to add reports' | translate }}\"\n placement=\"top\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n *ngIf=\"!canAddReport\"\n >\n <i\n class=\"text-primary\"\n [c8yIcon]=\"'info-circle'\"\n ></i>\n </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Reload' | translate }}\"\n type=\"button\"\n (click)=\"loadReports()\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': reloading }\"\n ></i>\n {{ 'Reload' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/working-with-reports/#working-with-reports\"></c8y-help>\n\n<c8y-list-group>\n <c8y-li\n class=\"page-sticky-header hidden-xs hidden-sm\"\n *ngIf=\"(reports$ | async)?.data.length > 0\"\n >\n <c8y-li-icon>\n <i class=\"p-l-24\"></i>\n </c8y-li-icon>\n <c8y-li-body class=\"content-flex-60\">\n <div class=\"col-3\">\n {{ 'Report' | translate }}\n </div>\n <div class=\"col-6\">\n {{ 'Description' | translate }}\n </div>\n <div class=\"col-2\">\n {{ 'Show in navigator' | translate }}\n </div>\n </c8y-li-body>\n </c8y-li>\n\n <c8y-li *c8yFor=\"let report of reports$; let i = index; loadMore: 'auto'\">\n <c8y-li-icon [icon]=\"report.icon\"></c8y-li-icon>\n <c8y-li-body class=\"content-flex-60\">\n <div class=\"col-3\">\n <button\n class=\"btn-clean\"\n title=\"{{ report.name }}\"\n type=\"button\"\n routerLink=\"/reports/{{ report.id }}\"\n >\n <span class=\"text-truncate\">\n {{ report.name }}\n </span>\n </button>\n </div>\n <div class=\"col-6\">\n <p class=\"small text-truncate-wrap\">\n <em\n class=\"text-muted\"\n *ngIf=\"!report.description; else showDescription\"\n >\n {{ 'No description available' | translate }}\n </em>\n <ng-template #showDescription>\n {{ report.description }}\n </ng-template>\n </p>\n </div>\n <div class=\"col-2 fit-h-20 m-t-xs-8\">\n <label\n class=\"c8y-switch c8y-switch--inline\"\n title=\"{{ 'Show in navigator' | translate }}\"\n >\n <input\n type=\"checkbox\"\n [(ngModel)]=\"!!report.c8y_IsNavigatorNode\"\n (change)=\"update(report)\"\n />\n <span></span>\n <span class=\"visible-xs\">\n {{ 'Show in navigator' | translate }}\n </span>\n </label>\n </div>\n <div class=\"col-1 hidden-xs\">\n <button\n class=\"btn btn-dot btn-dot--danger showOnHover m-l-auto d-flex\"\n [attr.aria-label]=\"'Remove report' | translate\"\n tooltip=\"{{ 'Remove report' | translate }}\"\n type=\"button\"\n [delay]=\"500\"\n (click)=\"delete(report)\"\n >\n <i c8yIcon=\"minus-circle\"></i>\n </button>\n </div>\n <div class=\"visible-xs p-t-8 text-right\">\n <button\n class=\"btn btn-default btn-sm\"\n title=\"{{ 'Remove report' | translate }}\"\n type=\"button\"\n (click)=\"delete(report)\"\n >\n <i c8yIcon=\"delete\"></i>\n {{ 'Remove report' | translate }}\n </button>\n </div>\n </c8y-li-body>\n </c8y-li>\n</c8y-list-group>\n\n<c8y-ui-empty-state\n [icon]=\"'c8y-reports'\"\n [title]=\"'There are no reports defined.' | translate\"\n [subtitle]=\"'Add a report first.' | translate\"\n *ngIf=\"(reports$ | async)?.data.length === 0\"\n>\n <p>\n <button\n class=\"btn btn-primary\"\n title=\"{{ 'Add report' | translate }}\"\n type=\"button\"\n [attr.data-cy]=\"'reports-add-report-empty-state-button'\"\n [disabled]=\"!canAddReport\"\n (click)=\"add()\"\n >\n {{ 'Add report' | translate }}\n </button>\n </p>\n <p c8y-guide-docs>\n <small\n translate\n ngNonBindable\n >\n Find out more in the\n <a c8y-guide-href=\"/docs/cockpit/working-with-reports\">user documentation</a>\n .\n </small>\n </p>\n</c8y-ui-empty-state>\n", dependencies: [{ kind: "component", type: i5.ActionBarItemComponent, selector: "c8y-action-bar-item", inputs: ["placement", "priority", "itemClass", "injector", "groupId", "inGroupPriority"] }, { kind: "component", type: i5.EmptyStateComponent, selector: "c8y-ui-empty-state", inputs: ["icon", "title", "subtitle", "horizontal"] }, { kind: "directive", type: i5.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i5.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.ForOfDirective, selector: "[c8yFor]", inputs: ["c8yForOf", "c8yForLoadMore", "c8yForPipe", "c8yForNotFound", "c8yForMaxIterations", "c8yForLoadingTemplate", "c8yForLoadNextLabel", "c8yForRealtime", "c8yForRealtimeOptions", "c8yForComparator", "c8yForEnableVirtualScroll", "c8yForVirtualScrollElementSize", "c8yForVirtualScrollStrategy", "c8yForVirtualScrollContainerHeight"], outputs: ["c8yForCount"] }, { kind: "component", type: i5.TitleComponent, selector: "c8y-title", inputs: ["pageTitleUpdate"] }, { kind: "directive", type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i8.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.GuideHrefDirective, selector: "[c8y-guide-href]", inputs: ["c8y-guide-href"] }, { kind: "component", type: i5.GuideDocsComponent, selector: "[c8y-guide-docs]" }, { kind: "component", type: i5.ListGroupComponent, selector: "c8y-list-group" }, { kind: "component", type: i5.ListItemComponent, selector: "c8y-list-item, c8y-li", inputs: ["active", "emptyActions", "collapsed", "selectable"], outputs: ["collapsedChange"] }, { kind: "component", type: i5.ListItemIconComponent, selector: "c8y-list-item-icon, c8y-li-icon", inputs: ["icon", "status"] }, { kind: "component", type: i5.ListItemBodyComponent, selector: "c8y-list-item-body, c8y-li-body", inputs: ["body"] }, { kind: "component", type: i5.HelpComponent, selector: "c8y-help", inputs: ["src", "isCollapsed", "priority", "icon"] }, { kind: "directive", type: i9.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }, { kind: "directive", type: i10.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i11.PopoverDirective, selector: "[popover]", inputs: ["adaptivePosition", "boundariesElement", "popover", "popoverContext", "popoverTitle", "placement", "outsideClick", "triggers", "container", "containerClass", "isOpen", "delay"], outputs: ["onShown", "onHidden"], exportAs: ["bs-popover"] }, { kind: "pipe", type: i5.C8yTranslatePipe, name: "translate" }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }] });
148
+ ReportDashboardListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ReportDashboardListComponent, selector: "c8y-report-dashboard-list", viewQueries: [{ propertyName: "filter", first: true, predicate: FilterInputComponent, descendants: true }], ngImport: i0, template: "<c8y-title>\n {{ 'Reports' | translate }}\n</c8y-title>\n\n<c8y-action-bar-item\n [placement]=\"'left'\"\n itemClass=\"navbar-form\"\n>\n <div class=\"input-group input-group-search\">\n <input\n class=\"form-control\"\n [attr.aria-label]=\"'Filter' | translate\"\n placeholder=\"{{ 'Filter\u2026' | translate }}\"\n type=\"search\"\n [ngModel]=\"textFilter$ | async\"\n (ngModelChange)=\"textFilter$.next($event)\"\n />\n <span class=\"input-group-addon\">\n <i\n c8yIcon=\"search\"\n *ngIf=\"(textFilter$ | async).length === 0\"\n ></i>\n <i\n class=\"text-muted\"\n c8yIcon=\"times\"\n *ngIf=\"(textFilter$ | async).length > 0\"\n (click)=\"textFilter$.next('')\"\n px-event=\"Clear filtering reports\"\n ></i>\n </span>\n </div>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add report' | translate }}\"\n type=\"button\"\n [attr.data-cy]=\"'reports-add-report-action-bar-button'\"\n (click)=\"add()\"\n [disabled]=\"!canAddReport\"\n >\n <i c8yIcon=\"plus-circle\"></i>\n {{ 'Add report' | translate }}\n </button>\n <button\n class=\"btn btn-dot m-r-16\"\n aria-label=\"{{ 'Info' | translate }}\"\n popover=\"{{ 'You don\\'t have permission to add reports' | translate }}\"\n placement=\"top\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n *ngIf=\"!canAddReport\"\n >\n <i\n class=\"text-primary\"\n [c8yIcon]=\"'info-circle'\"\n ></i>\n </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Reload' | translate }}\"\n type=\"button\"\n (click)=\"loadReports()\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': reloading }\"\n ></i>\n {{ 'Reload' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/working-with-reports/#working-with-reports\"></c8y-help>\n\n<c8y-list-group>\n <c8y-li\n class=\"page-sticky-header hidden-xs hidden-sm\"\n *ngIf=\"(reports$ | async)?.data.length > 0\"\n >\n <c8y-li-icon>\n <i class=\"p-l-24\"></i>\n </c8y-li-icon>\n <c8y-li-body class=\"content-flex-60\">\n <div class=\"col-3\">\n {{ 'Report' | translate }}\n </div>\n <div class=\"col-6\">\n {{ 'Description' | translate }}\n </div>\n <div class=\"col-2\">\n {{ 'Show in navigator' | translate }}\n </div>\n </c8y-li-body>\n </c8y-li>\n\n <c8y-li *c8yFor=\"let report of reports$; let i = index; loadMore: 'auto'\">\n <c8y-li-icon [icon]=\"report.icon\"></c8y-li-icon>\n <c8y-li-body class=\"content-flex-60\">\n <div class=\"col-3\">\n <button\n class=\"btn-clean\"\n title=\"{{ report.name }}\"\n type=\"button\"\n routerLink=\"/reports/{{ report.id }}\"\n >\n <span class=\"text-truncate\">\n {{ report.name }}\n </span>\n </button>\n </div>\n <div class=\"col-6\">\n <p class=\"small text-truncate-wrap\">\n <em\n class=\"text-muted\"\n *ngIf=\"!report.description; else showDescription\"\n >\n {{ 'No description available' | translate }}\n </em>\n <ng-template #showDescription>\n {{ report.description }}\n </ng-template>\n </p>\n </div>\n <div class=\"col-2 fit-h-20 m-t-xs-8\">\n <label\n class=\"c8y-switch c8y-switch--inline\"\n title=\"{{ 'Show in navigator' | translate }}\"\n >\n <input\n type=\"checkbox\"\n [(ngModel)]=\"!!report.c8y_IsNavigatorNode\"\n (change)=\"update(report)\"\n />\n <span></span>\n <span class=\"visible-xs\">\n {{ 'Show in navigator' | translate }}\n </span>\n </label>\n </div>\n <div class=\"col-1 hidden-xs\">\n <button\n class=\"btn btn-dot btn-dot--danger showOnHover m-l-auto d-flex\"\n [attr.aria-label]=\"'Remove report' | translate\"\n tooltip=\"{{ 'Remove report' | translate }}\"\n type=\"button\"\n [delay]=\"500\"\n (click)=\"delete(report)\"\n >\n <i c8yIcon=\"minus-circle\"></i>\n </button>\n </div>\n <div class=\"visible-xs p-t-8 text-right\">\n <button\n class=\"btn btn-default btn-sm\"\n title=\"{{ 'Remove report' | translate }}\"\n type=\"button\"\n (click)=\"delete(report)\"\n >\n <i c8yIcon=\"delete\"></i>\n {{ 'Remove report' | translate }}\n </button>\n </div>\n </c8y-li-body>\n </c8y-li>\n</c8y-list-group>\n\n<c8y-ui-empty-state\n [icon]=\"'c8y-reports'\"\n [title]=\"'There are no reports defined.' | translate\"\n [subtitle]=\"'Add a report first.' | translate\"\n *ngIf=\"(reports$ | async)?.data.length === 0\"\n>\n <p>\n <button\n class=\"btn btn-primary\"\n title=\"{{ 'Add report' | translate }}\"\n type=\"button\"\n [attr.data-cy]=\"'reports-add-report-empty-state-button'\"\n [disabled]=\"!canAddReport\"\n (click)=\"add()\"\n c8yProductExperience\n [actionName]=\"PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.REPORTS\"\n [actionData]=\"{ action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.ADD_REPORT }\"\n >\n {{ 'Add report' | translate }}\n </button>\n </p>\n <p c8y-guide-docs>\n <small\n translate\n ngNonBindable\n >\n Find out more in the\n <a c8y-guide-href=\"/docs/cockpit/working-with-reports\">user documentation</a>\n .\n </small>\n </p>\n</c8y-ui-empty-state>\n", dependencies: [{ kind: "component", type: i5.ActionBarItemComponent, selector: "c8y-action-bar-item", inputs: ["placement", "priority", "itemClass", "injector", "groupId", "inGroupPriority"] }, { kind: "component", type: i5.EmptyStateComponent, selector: "c8y-ui-empty-state", inputs: ["icon", "title", "subtitle", "horizontal"] }, { kind: "directive", type: i5.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i5.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.ForOfDirective, selector: "[c8yFor]", inputs: ["c8yForOf", "c8yForLoadMore", "c8yForPipe", "c8yForNotFound", "c8yForMaxIterations", "c8yForLoadingTemplate", "c8yForLoadNextLabel", "c8yForRealtime", "c8yForRealtimeOptions", "c8yForComparator", "c8yForEnableVirtualScroll", "c8yForVirtualScrollElementSize", "c8yForVirtualScrollStrategy", "c8yForVirtualScrollContainerHeight"], outputs: ["c8yForCount"] }, { kind: "component", type: i5.TitleComponent, selector: "c8y-title", inputs: ["pageTitleUpdate"] }, { kind: "directive", type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i8.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.GuideHrefDirective, selector: "[c8y-guide-href]", inputs: ["c8y-guide-href"] }, { kind: "component", type: i5.GuideDocsComponent, selector: "[c8y-guide-docs]" }, { kind: "component", type: i5.ListGroupComponent, selector: "c8y-list-group" }, { kind: "component", type: i5.ListItemComponent, selector: "c8y-list-item, c8y-li", inputs: ["active", "emptyActions", "collapsed", "selectable"], outputs: ["collapsedChange"] }, { kind: "component", type: i5.ListItemIconComponent, selector: "c8y-list-item-icon, c8y-li-icon", inputs: ["icon", "status"] }, { kind: "component", type: i5.ListItemBodyComponent, selector: "c8y-list-item-body, c8y-li-body", inputs: ["body"] }, { kind: "directive", type: i5.ProductExperienceDirective, selector: "[c8yProductExperience]", inputs: ["actionName", "actionData", "inherit", "suppressDataOverriding"] }, { kind: "component", type: i5.HelpComponent, selector: "c8y-help", inputs: ["src", "isCollapsed", "priority", "icon"] }, { kind: "directive", type: i9.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }, { kind: "directive", type: i10.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i11.PopoverDirective, selector: "[popover]", inputs: ["adaptivePosition", "boundariesElement", "popover", "popoverContext", "popoverTitle", "placement", "outsideClick", "triggers", "container", "containerClass", "isOpen", "delay"], outputs: ["onShown", "onHidden"], exportAs: ["bs-popover"] }, { kind: "pipe", type: i5.C8yTranslatePipe, name: "translate" }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }] });
148
149
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ReportDashboardListComponent, decorators: [{
149
150
  type: Component,
150
- args: [{ selector: 'c8y-report-dashboard-list', template: "<c8y-title>\n {{ 'Reports' | translate }}\n</c8y-title>\n\n<c8y-action-bar-item\n [placement]=\"'left'\"\n itemClass=\"navbar-form\"\n>\n <div class=\"input-group input-group-search\">\n <input\n class=\"form-control\"\n [attr.aria-label]=\"'Filter' | translate\"\n placeholder=\"{{ 'Filter\u2026' | translate }}\"\n type=\"search\"\n [ngModel]=\"textFilter$ | async\"\n (ngModelChange)=\"textFilter$.next($event)\"\n />\n <span class=\"input-group-addon\">\n <i\n c8yIcon=\"search\"\n *ngIf=\"(textFilter$ | async).length === 0\"\n ></i>\n <i\n class=\"text-muted\"\n c8yIcon=\"times\"\n *ngIf=\"(textFilter$ | async).length > 0\"\n (click)=\"textFilter$.next('')\"\n px-event=\"Clear filtering reports\"\n ></i>\n </span>\n </div>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add report' | translate }}\"\n type=\"button\"\n [attr.data-cy]=\"'reports-add-report-action-bar-button'\"\n (click)=\"add()\"\n [disabled]=\"!canAddReport\"\n >\n <i c8yIcon=\"plus-circle\"></i>\n {{ 'Add report' | translate }}\n </button>\n <button\n class=\"btn btn-dot m-r-16\"\n aria-label=\"{{ 'Info' | translate }}\"\n popover=\"{{ 'You don\\'t have permission to add reports' | translate }}\"\n placement=\"top\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n *ngIf=\"!canAddReport\"\n >\n <i\n class=\"text-primary\"\n [c8yIcon]=\"'info-circle'\"\n ></i>\n </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Reload' | translate }}\"\n type=\"button\"\n (click)=\"loadReports()\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': reloading }\"\n ></i>\n {{ 'Reload' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/working-with-reports/#working-with-reports\"></c8y-help>\n\n<c8y-list-group>\n <c8y-li\n class=\"page-sticky-header hidden-xs hidden-sm\"\n *ngIf=\"(reports$ | async)?.data.length > 0\"\n >\n <c8y-li-icon>\n <i class=\"p-l-24\"></i>\n </c8y-li-icon>\n <c8y-li-body class=\"content-flex-60\">\n <div class=\"col-3\">\n {{ 'Report' | translate }}\n </div>\n <div class=\"col-6\">\n {{ 'Description' | translate }}\n </div>\n <div class=\"col-2\">\n {{ 'Show in navigator' | translate }}\n </div>\n </c8y-li-body>\n </c8y-li>\n\n <c8y-li *c8yFor=\"let report of reports$; let i = index; loadMore: 'auto'\">\n <c8y-li-icon [icon]=\"report.icon\"></c8y-li-icon>\n <c8y-li-body class=\"content-flex-60\">\n <div class=\"col-3\">\n <button\n class=\"btn-clean\"\n title=\"{{ report.name }}\"\n type=\"button\"\n routerLink=\"/reports/{{ report.id }}\"\n >\n <span class=\"text-truncate\">\n {{ report.name }}\n </span>\n </button>\n </div>\n <div class=\"col-6\">\n <p class=\"small text-truncate-wrap\">\n <em\n class=\"text-muted\"\n *ngIf=\"!report.description; else showDescription\"\n >\n {{ 'No description available' | translate }}\n </em>\n <ng-template #showDescription>\n {{ report.description }}\n </ng-template>\n </p>\n </div>\n <div class=\"col-2 fit-h-20 m-t-xs-8\">\n <label\n class=\"c8y-switch c8y-switch--inline\"\n title=\"{{ 'Show in navigator' | translate }}\"\n >\n <input\n type=\"checkbox\"\n [(ngModel)]=\"!!report.c8y_IsNavigatorNode\"\n (change)=\"update(report)\"\n />\n <span></span>\n <span class=\"visible-xs\">\n {{ 'Show in navigator' | translate }}\n </span>\n </label>\n </div>\n <div class=\"col-1 hidden-xs\">\n <button\n class=\"btn btn-dot btn-dot--danger showOnHover m-l-auto d-flex\"\n [attr.aria-label]=\"'Remove report' | translate\"\n tooltip=\"{{ 'Remove report' | translate }}\"\n type=\"button\"\n [delay]=\"500\"\n (click)=\"delete(report)\"\n >\n <i c8yIcon=\"minus-circle\"></i>\n </button>\n </div>\n <div class=\"visible-xs p-t-8 text-right\">\n <button\n class=\"btn btn-default btn-sm\"\n title=\"{{ 'Remove report' | translate }}\"\n type=\"button\"\n (click)=\"delete(report)\"\n >\n <i c8yIcon=\"delete\"></i>\n {{ 'Remove report' | translate }}\n </button>\n </div>\n </c8y-li-body>\n </c8y-li>\n</c8y-list-group>\n\n<c8y-ui-empty-state\n [icon]=\"'c8y-reports'\"\n [title]=\"'There are no reports defined.' | translate\"\n [subtitle]=\"'Add a report first.' | translate\"\n *ngIf=\"(reports$ | async)?.data.length === 0\"\n>\n <p>\n <button\n class=\"btn btn-primary\"\n title=\"{{ 'Add report' | translate }}\"\n type=\"button\"\n [attr.data-cy]=\"'reports-add-report-empty-state-button'\"\n [disabled]=\"!canAddReport\"\n (click)=\"add()\"\n >\n {{ 'Add report' | translate }}\n </button>\n </p>\n <p c8y-guide-docs>\n <small\n translate\n ngNonBindable\n >\n Find out more in the\n <a c8y-guide-href=\"/docs/cockpit/working-with-reports\">user documentation</a>\n .\n </small>\n </p>\n</c8y-ui-empty-state>\n" }]
151
+ args: [{ selector: 'c8y-report-dashboard-list', template: "<c8y-title>\n {{ 'Reports' | translate }}\n</c8y-title>\n\n<c8y-action-bar-item\n [placement]=\"'left'\"\n itemClass=\"navbar-form\"\n>\n <div class=\"input-group input-group-search\">\n <input\n class=\"form-control\"\n [attr.aria-label]=\"'Filter' | translate\"\n placeholder=\"{{ 'Filter\u2026' | translate }}\"\n type=\"search\"\n [ngModel]=\"textFilter$ | async\"\n (ngModelChange)=\"textFilter$.next($event)\"\n />\n <span class=\"input-group-addon\">\n <i\n c8yIcon=\"search\"\n *ngIf=\"(textFilter$ | async).length === 0\"\n ></i>\n <i\n class=\"text-muted\"\n c8yIcon=\"times\"\n *ngIf=\"(textFilter$ | async).length > 0\"\n (click)=\"textFilter$.next('')\"\n px-event=\"Clear filtering reports\"\n ></i>\n </span>\n </div>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add report' | translate }}\"\n type=\"button\"\n [attr.data-cy]=\"'reports-add-report-action-bar-button'\"\n (click)=\"add()\"\n [disabled]=\"!canAddReport\"\n >\n <i c8yIcon=\"plus-circle\"></i>\n {{ 'Add report' | translate }}\n </button>\n <button\n class=\"btn btn-dot m-r-16\"\n aria-label=\"{{ 'Info' | translate }}\"\n popover=\"{{ 'You don\\'t have permission to add reports' | translate }}\"\n placement=\"top\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n *ngIf=\"!canAddReport\"\n >\n <i\n class=\"text-primary\"\n [c8yIcon]=\"'info-circle'\"\n ></i>\n </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Reload' | translate }}\"\n type=\"button\"\n (click)=\"loadReports()\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': reloading }\"\n ></i>\n {{ 'Reload' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/working-with-reports/#working-with-reports\"></c8y-help>\n\n<c8y-list-group>\n <c8y-li\n class=\"page-sticky-header hidden-xs hidden-sm\"\n *ngIf=\"(reports$ | async)?.data.length > 0\"\n >\n <c8y-li-icon>\n <i class=\"p-l-24\"></i>\n </c8y-li-icon>\n <c8y-li-body class=\"content-flex-60\">\n <div class=\"col-3\">\n {{ 'Report' | translate }}\n </div>\n <div class=\"col-6\">\n {{ 'Description' | translate }}\n </div>\n <div class=\"col-2\">\n {{ 'Show in navigator' | translate }}\n </div>\n </c8y-li-body>\n </c8y-li>\n\n <c8y-li *c8yFor=\"let report of reports$; let i = index; loadMore: 'auto'\">\n <c8y-li-icon [icon]=\"report.icon\"></c8y-li-icon>\n <c8y-li-body class=\"content-flex-60\">\n <div class=\"col-3\">\n <button\n class=\"btn-clean\"\n title=\"{{ report.name }}\"\n type=\"button\"\n routerLink=\"/reports/{{ report.id }}\"\n >\n <span class=\"text-truncate\">\n {{ report.name }}\n </span>\n </button>\n </div>\n <div class=\"col-6\">\n <p class=\"small text-truncate-wrap\">\n <em\n class=\"text-muted\"\n *ngIf=\"!report.description; else showDescription\"\n >\n {{ 'No description available' | translate }}\n </em>\n <ng-template #showDescription>\n {{ report.description }}\n </ng-template>\n </p>\n </div>\n <div class=\"col-2 fit-h-20 m-t-xs-8\">\n <label\n class=\"c8y-switch c8y-switch--inline\"\n title=\"{{ 'Show in navigator' | translate }}\"\n >\n <input\n type=\"checkbox\"\n [(ngModel)]=\"!!report.c8y_IsNavigatorNode\"\n (change)=\"update(report)\"\n />\n <span></span>\n <span class=\"visible-xs\">\n {{ 'Show in navigator' | translate }}\n </span>\n </label>\n </div>\n <div class=\"col-1 hidden-xs\">\n <button\n class=\"btn btn-dot btn-dot--danger showOnHover m-l-auto d-flex\"\n [attr.aria-label]=\"'Remove report' | translate\"\n tooltip=\"{{ 'Remove report' | translate }}\"\n type=\"button\"\n [delay]=\"500\"\n (click)=\"delete(report)\"\n >\n <i c8yIcon=\"minus-circle\"></i>\n </button>\n </div>\n <div class=\"visible-xs p-t-8 text-right\">\n <button\n class=\"btn btn-default btn-sm\"\n title=\"{{ 'Remove report' | translate }}\"\n type=\"button\"\n (click)=\"delete(report)\"\n >\n <i c8yIcon=\"delete\"></i>\n {{ 'Remove report' | translate }}\n </button>\n </div>\n </c8y-li-body>\n </c8y-li>\n</c8y-list-group>\n\n<c8y-ui-empty-state\n [icon]=\"'c8y-reports'\"\n [title]=\"'There are no reports defined.' | translate\"\n [subtitle]=\"'Add a report first.' | translate\"\n *ngIf=\"(reports$ | async)?.data.length === 0\"\n>\n <p>\n <button\n class=\"btn btn-primary\"\n title=\"{{ 'Add report' | translate }}\"\n type=\"button\"\n [attr.data-cy]=\"'reports-add-report-empty-state-button'\"\n [disabled]=\"!canAddReport\"\n (click)=\"add()\"\n c8yProductExperience\n [actionName]=\"PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.REPORTS\"\n [actionData]=\"{ action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.ADD_REPORT }\"\n >\n {{ 'Add report' | translate }}\n </button>\n </p>\n <p c8y-guide-docs>\n <small\n translate\n ngNonBindable\n >\n Find out more in the\n <a c8y-guide-href=\"/docs/cockpit/working-with-reports\">user documentation</a>\n .\n </small>\n </p>\n</c8y-ui-empty-state>\n" }]
151
152
  }], ctorParameters: function () { return [{ type: i1.InventoryService }, { type: i2.ContextDashboardService }, { type: i3.BsModalService }, { type: i4.TranslateService }, { type: i5.ModalService }, { type: i5.AlertService }, { type: i6.ReportDashboardService }, { type: i5.Permissions }, { type: i5.GainsightService }]; }, propDecorators: { filter: [{
152
153
  type: ViewChild,
153
154
  args: [FilterInputComponent, { static: false }]
154
155
  }] } });
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-dashboard-list.component.js","sourceRoot":"","sources":["../../../../context-dashboard/report-dashboard/report-dashboard-list.component.ts","../../../../context-dashboard/report-dashboard/report-dashboard-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild } from '@angular/core';\nimport { BehaviorSubject, combineLatest, Observable } from 'rxjs';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { IManagedObject, InventoryService, IResultList } from '@c8y/client';\nimport { debounceTime, distinctUntilChanged, shareReplay, switchMap, tap } from 'rxjs/operators';\nimport {\n  FilterInputComponent,\n  gettext,\n  ModalService,\n  Status,\n  AlertService,\n  Permissions,\n  GainsightService\n} from '@c8y/ngx-components';\nimport { DashboardDetailComponent } from '../dashboard-detail.component';\nimport { ContextDashboardService } from '../context-dashboard.service';\nimport { ContextDashboardType, PRODUCT_EXPERIENCE } from '../context-dashboard.model';\nimport { TranslateService } from '@ngx-translate/core';\nimport { ReportDashboardService } from './report-dashboard.service';\n\n@Component({\n  selector: 'c8y-report-dashboard-list',\n  templateUrl: './report-dashboard-list.component.html'\n})\nexport class ReportDashboardListComponent implements OnInit {\n  @ViewChild(FilterInputComponent, { static: false }) filter: FilterInputComponent;\n  textFilter$: BehaviorSubject<string> = new BehaviorSubject('');\n  reload$: BehaviorSubject<void> = new BehaviorSubject(null);\n  reloading = false;\n  reports$: Observable<IResultList<IManagedObject>> = combineLatest(\n    this.textFilter$.pipe(debounceTime(400), distinctUntilChanged()),\n    this.reload$\n  ).pipe(\n    tap(() => {\n      this.reloading = true;\n    }),\n    switchMap(([text]) => this.loadReports(text)),\n    tap(() => {\n      this.reloading = false;\n    }),\n    shareReplay(1)\n  );\n  canAddReport = false;\n  private readonly DELETED_SUCCESS_MSG = gettext('Report deleted.');\n\n  constructor(\n    private inventoryService: InventoryService,\n    private contextDashboardService: ContextDashboardService,\n    private bsModal: BsModalService,\n    private translateService: TranslateService,\n    private modal: ModalService,\n    private alertService: AlertService,\n    private reportDashboardService: ReportDashboardService,\n    private permissions: Permissions,\n    private gainsightService: GainsightService\n  ) {}\n\n  ngOnInit() {\n    this.canAddReport = this.permissions.hasAnyRole([\n      Permissions.ROLE_INVENTORY_CREATE,\n      Permissions.ROLE_INVENTORY_ADMIN,\n      Permissions.ROLE_MANAGED_OBJECT_ADMIN,\n      Permissions.ROLE_MANAGED_OBJECT_CREATE\n    ]);\n  }\n\n  async loadReports(partialName?: string) {\n    return partialName\n      ? this.reportDashboardService.listReports({ filter: { name: `*${partialName}*` } })\n      : this.reportDashboardService.listReports();\n  }\n\n  async add() {\n    const initialState = {\n      isReport: true,\n      isNamedDashboard: true\n    };\n    const modal = this.bsModal.show(DashboardDetailComponent, {\n      class: 'modal-lg',\n      ignoreBackdropClick: true,\n      keyboard: false,\n      ariaDescribedby: 'modal-body',\n      ariaLabelledBy: 'modal-title',\n      initialState\n    }).content as DashboardDetailComponent;\n    try {\n      const cfg = await modal.result;\n      const { name, icon, c8y_IsNavigatorNode, priority, description, ...dashboardCfg } = cfg;\n      const report = (\n        await this.reportDashboardService.createReport({\n          name,\n          icon,\n          c8y_IsNavigatorNode,\n          priority,\n          description\n        } as Partial<IManagedObject>)\n      ).data;\n\n      await this.contextDashboardService.create(\n        dashboardCfg,\n        undefined,\n        `${this.contextDashboardService.REPORT_PARTIAL_NAME}${report.id}`\n      );\n      if (report.c8y_IsNavigatorNode) {\n        this.reportDashboardService.addReportNavigatorNode(report);\n      }\n      this.reload$.next();\n      modal.close();\n      this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.REPORTS, {\n        component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.ADD_REPORT,\n        action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.CREATE,\n        name: report.name,\n        id: report.id,\n        context: PRODUCT_EXPERIENCE.DASHBOARD.CONTEXT.REPORT\n      });\n    } catch (ex) {\n      if (ex) {\n        throw new Error(`Something went wrong: ${ex}`);\n      }\n    }\n  }\n\n  async delete(report: IManagedObject) {\n    try {\n      const dashboard = await this.contextDashboardService\n        .getDashboard$(`report_${report.id}`, [ContextDashboardType.Named])\n        .toPromise();\n      const isDashboardFrozen = !!dashboard?.c8y_Dashboard?.isFrozen;\n\n      const msg = isDashboardFrozen\n        ? gettext(\n            `You are about to delete the report \"{{ reportName }}\". Be aware that the report has a locked dashboard assigned. Do you want to proceed?`\n          )\n        : gettext(`You are about to delete the report \"{{ reportName }}\". Do you want to proceed?`);\n\n      await this.modal.confirm(\n        gettext('Delete report'),\n        this.translateService.instant(msg, {\n          reportName: report.name\n        }),\n        Status.DANGER,\n        {\n          ok: gettext('Delete'),\n          cancel: gettext('Cancel')\n        }\n      );\n\n      await this.contextDashboardService.delete(dashboard, false);\n      await this.inventoryService.delete(report.id);\n      this.alertService.success(this.DELETED_SUCCESS_MSG);\n      if (report.c8y_IsNavigatorNode) {\n        this.reportDashboardService.removeNavigatorNode(report);\n      }\n      this.reload$.next();\n      this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.REPORTS, {\n        component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.REPORTS_LIST,\n        action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.DELETE,\n        name: report.name,\n        id: report.id,\n        context: PRODUCT_EXPERIENCE.DASHBOARD.CONTEXT.REPORT\n      });\n    } catch (ex) {\n      if (ex) {\n        throw new Error(`Something went wrong: ${ex}`);\n      }\n    }\n  }\n\n  async update(report: IManagedObject) {\n    report.c8y_IsNavigatorNode = report.c8y_IsNavigatorNode ? {} : null;\n    await this.inventoryService.update(report);\n    report.c8y_IsNavigatorNode\n      ? this.reportDashboardService.addReportNavigatorNode(report)\n      : this.reportDashboardService.removeNavigatorNode(report);\n  }\n}\n","<c8y-title>\n  {{ 'Reports' | translate }}\n</c8y-title>\n\n<c8y-action-bar-item\n  [placement]=\"'left'\"\n  itemClass=\"navbar-form\"\n>\n  <div class=\"input-group input-group-search\">\n    <input\n      class=\"form-control\"\n      [attr.aria-label]=\"'Filter' | translate\"\n      placeholder=\"{{ 'Filter…' | translate }}\"\n      type=\"search\"\n      [ngModel]=\"textFilter$ | async\"\n      (ngModelChange)=\"textFilter$.next($event)\"\n    />\n    <span class=\"input-group-addon\">\n      <i\n        c8yIcon=\"search\"\n        *ngIf=\"(textFilter$ | async).length === 0\"\n      ></i>\n      <i\n        class=\"text-muted\"\n        c8yIcon=\"times\"\n        *ngIf=\"(textFilter$ | async).length > 0\"\n        (click)=\"textFilter$.next('')\"\n        px-event=\"Clear filtering reports\"\n      ></i>\n    </span>\n  </div>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Add report' | translate }}\"\n    type=\"button\"\n    [attr.data-cy]=\"'reports-add-report-action-bar-button'\"\n    (click)=\"add()\"\n    [disabled]=\"!canAddReport\"\n  >\n    <i c8yIcon=\"plus-circle\"></i>\n    {{ 'Add report' | translate }}\n  </button>\n  <button\n    class=\"btn btn-dot m-r-16\"\n    aria-label=\"{{ 'Info' | translate }}\"\n    popover=\"{{ 'You don\\'t have permission to add reports' | translate }}\"\n    placement=\"top\"\n    triggers=\"focus\"\n    container=\"body\"\n    type=\"button\"\n    *ngIf=\"!canAddReport\"\n  >\n    <i\n      class=\"text-primary\"\n      [c8yIcon]=\"'info-circle'\"\n    ></i>\n  </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Reload' | translate }}\"\n    type=\"button\"\n    (click)=\"loadReports()\"\n  >\n    <i\n      c8yIcon=\"refresh\"\n      [ngClass]=\"{ 'icon-spin': reloading }\"\n    ></i>\n    {{ 'Reload' | translate }}\n  </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/working-with-reports/#working-with-reports\"></c8y-help>\n\n<c8y-list-group>\n  <c8y-li\n    class=\"page-sticky-header hidden-xs hidden-sm\"\n    *ngIf=\"(reports$ | async)?.data.length > 0\"\n  >\n    <c8y-li-icon>\n      <i class=\"p-l-24\"></i>\n    </c8y-li-icon>\n    <c8y-li-body class=\"content-flex-60\">\n      <div class=\"col-3\">\n        {{ 'Report' | translate }}\n      </div>\n      <div class=\"col-6\">\n        {{ 'Description' | translate }}\n      </div>\n      <div class=\"col-2\">\n        {{ 'Show in navigator' | translate }}\n      </div>\n    </c8y-li-body>\n  </c8y-li>\n\n  <c8y-li *c8yFor=\"let report of reports$; let i = index; loadMore: 'auto'\">\n    <c8y-li-icon [icon]=\"report.icon\"></c8y-li-icon>\n    <c8y-li-body class=\"content-flex-60\">\n      <div class=\"col-3\">\n        <button\n          class=\"btn-clean\"\n          title=\"{{ report.name }}\"\n          type=\"button\"\n          routerLink=\"/reports/{{ report.id }}\"\n        >\n          <span class=\"text-truncate\">\n            {{ report.name }}\n          </span>\n        </button>\n      </div>\n      <div class=\"col-6\">\n        <p class=\"small text-truncate-wrap\">\n          <em\n            class=\"text-muted\"\n            *ngIf=\"!report.description; else showDescription\"\n          >\n            {{ 'No description available' | translate }}\n          </em>\n          <ng-template #showDescription>\n            {{ report.description }}\n          </ng-template>\n        </p>\n      </div>\n      <div class=\"col-2 fit-h-20 m-t-xs-8\">\n        <label\n          class=\"c8y-switch c8y-switch--inline\"\n          title=\"{{ 'Show in navigator' | translate }}\"\n        >\n          <input\n            type=\"checkbox\"\n            [(ngModel)]=\"!!report.c8y_IsNavigatorNode\"\n            (change)=\"update(report)\"\n          />\n          <span></span>\n          <span class=\"visible-xs\">\n            {{ 'Show in navigator' | translate }}\n          </span>\n        </label>\n      </div>\n      <div class=\"col-1 hidden-xs\">\n        <button\n          class=\"btn btn-dot btn-dot--danger showOnHover m-l-auto d-flex\"\n          [attr.aria-label]=\"'Remove report' | translate\"\n          tooltip=\"{{ 'Remove report' | translate }}\"\n          type=\"button\"\n          [delay]=\"500\"\n          (click)=\"delete(report)\"\n        >\n          <i c8yIcon=\"minus-circle\"></i>\n        </button>\n      </div>\n      <div class=\"visible-xs p-t-8 text-right\">\n        <button\n          class=\"btn btn-default btn-sm\"\n          title=\"{{ 'Remove report' | translate }}\"\n          type=\"button\"\n          (click)=\"delete(report)\"\n        >\n          <i c8yIcon=\"delete\"></i>\n          {{ 'Remove report' | translate }}\n        </button>\n      </div>\n    </c8y-li-body>\n  </c8y-li>\n</c8y-list-group>\n\n<c8y-ui-empty-state\n  [icon]=\"'c8y-reports'\"\n  [title]=\"'There are no reports defined.' | translate\"\n  [subtitle]=\"'Add a report first.' | translate\"\n  *ngIf=\"(reports$ | async)?.data.length === 0\"\n>\n  <p>\n    <button\n      class=\"btn btn-primary\"\n      title=\"{{ 'Add report' | translate }}\"\n      type=\"button\"\n      [attr.data-cy]=\"'reports-add-report-empty-state-button'\"\n      [disabled]=\"!canAddReport\"\n      (click)=\"add()\"\n    >\n      {{ 'Add report' | translate }}\n    </button>\n  </p>\n  <p c8y-guide-docs>\n    <small\n      translate\n      ngNonBindable\n    >\n      Find out more in the\n      <a c8y-guide-href=\"/docs/cockpit/working-with-reports\">user documentation</a>\n      .\n    </small>\n  </p>\n</c8y-ui-empty-state>\n"]}
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-dashboard-list.component.js","sourceRoot":"","sources":["../../../../context-dashboard/report-dashboard/report-dashboard-list.component.ts","../../../../context-dashboard/report-dashboard/report-dashboard-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild } from '@angular/core';\nimport { BehaviorSubject, combineLatest, Observable } from 'rxjs';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { IManagedObject, InventoryService, IResultList } from '@c8y/client';\nimport { debounceTime, distinctUntilChanged, shareReplay, switchMap, tap } from 'rxjs/operators';\nimport {\n  FilterInputComponent,\n  gettext,\n  ModalService,\n  Status,\n  AlertService,\n  Permissions,\n  GainsightService\n} from '@c8y/ngx-components';\nimport { DashboardDetailComponent } from '../dashboard-detail.component';\nimport { ContextDashboardService } from '../context-dashboard.service';\nimport { ContextDashboardType, PRODUCT_EXPERIENCE } from '../context-dashboard.model';\nimport { TranslateService } from '@ngx-translate/core';\nimport { ReportDashboardService } from './report-dashboard.service';\n\n@Component({\n  selector: 'c8y-report-dashboard-list',\n  templateUrl: './report-dashboard-list.component.html'\n})\nexport class ReportDashboardListComponent implements OnInit {\n  PRODUCT_EXPERIENCE = PRODUCT_EXPERIENCE;\n\n  @ViewChild(FilterInputComponent, { static: false }) filter: FilterInputComponent;\n  textFilter$: BehaviorSubject<string> = new BehaviorSubject('');\n  reload$: BehaviorSubject<void> = new BehaviorSubject(null);\n  reloading = false;\n  reports$: Observable<IResultList<IManagedObject>> = combineLatest(\n    this.textFilter$.pipe(debounceTime(400), distinctUntilChanged()),\n    this.reload$\n  ).pipe(\n    tap(() => {\n      this.reloading = true;\n    }),\n    switchMap(([text]) => this.loadReports(text)),\n    tap(() => {\n      this.reloading = false;\n    }),\n    shareReplay(1)\n  );\n  canAddReport = false;\n  private readonly DELETED_SUCCESS_MSG = gettext('Report deleted.');\n\n  constructor(\n    private inventoryService: InventoryService,\n    private contextDashboardService: ContextDashboardService,\n    private bsModal: BsModalService,\n    private translateService: TranslateService,\n    private modal: ModalService,\n    private alertService: AlertService,\n    private reportDashboardService: ReportDashboardService,\n    private permissions: Permissions,\n    private gainsightService: GainsightService\n  ) {}\n\n  ngOnInit() {\n    this.canAddReport = this.permissions.hasAnyRole([\n      Permissions.ROLE_INVENTORY_CREATE,\n      Permissions.ROLE_INVENTORY_ADMIN,\n      Permissions.ROLE_MANAGED_OBJECT_ADMIN,\n      Permissions.ROLE_MANAGED_OBJECT_CREATE\n    ]);\n  }\n\n  async loadReports(partialName?: string) {\n    return partialName\n      ? this.reportDashboardService.listReports({ filter: { name: `*${partialName}*` } })\n      : this.reportDashboardService.listReports();\n  }\n\n  async add() {\n    const initialState = {\n      isReport: true,\n      isNamedDashboard: true\n    };\n    const modal = this.bsModal.show(DashboardDetailComponent, {\n      class: 'modal-lg',\n      ignoreBackdropClick: true,\n      keyboard: false,\n      ariaDescribedby: 'modal-body',\n      ariaLabelledBy: 'modal-title',\n      initialState\n    }).content as DashboardDetailComponent;\n    try {\n      const cfg = await modal.result;\n      const { name, icon, c8y_IsNavigatorNode, priority, description, ...dashboardCfg } = cfg;\n      const report = (\n        await this.reportDashboardService.createReport({\n          name,\n          icon,\n          c8y_IsNavigatorNode,\n          priority,\n          description\n        } as Partial<IManagedObject>)\n      ).data;\n\n      await this.contextDashboardService.create(\n        dashboardCfg,\n        undefined,\n        `${this.contextDashboardService.REPORT_PARTIAL_NAME}${report.id}`\n      );\n      if (report.c8y_IsNavigatorNode) {\n        this.reportDashboardService.addReportNavigatorNode(report);\n      }\n      this.reload$.next();\n      modal.close();\n      this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.REPORTS, {\n        component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.ADD_REPORT,\n        action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.CREATE,\n        name: report.name,\n        id: report.id,\n        context: PRODUCT_EXPERIENCE.DASHBOARD.CONTEXT.REPORT\n      });\n    } catch (ex) {\n      if (ex) {\n        throw new Error(`Something went wrong: ${ex}`);\n      }\n    }\n  }\n\n  async delete(report: IManagedObject) {\n    try {\n      const dashboard = await this.contextDashboardService\n        .getDashboard$(`report_${report.id}`, [ContextDashboardType.Named])\n        .toPromise();\n      const isDashboardFrozen = !!dashboard?.c8y_Dashboard?.isFrozen;\n\n      const msg = isDashboardFrozen\n        ? gettext(\n            `You are about to delete the report \"{{ reportName }}\". Be aware that the report has a locked dashboard assigned. Do you want to proceed?`\n          )\n        : gettext(`You are about to delete the report \"{{ reportName }}\". Do you want to proceed?`);\n\n      await this.modal.confirm(\n        gettext('Delete report'),\n        this.translateService.instant(msg, {\n          reportName: report.name\n        }),\n        Status.DANGER,\n        {\n          ok: gettext('Delete'),\n          cancel: gettext('Cancel')\n        }\n      );\n\n      await this.contextDashboardService.delete(dashboard, false);\n      await this.inventoryService.delete(report.id);\n      this.alertService.success(this.DELETED_SUCCESS_MSG);\n      if (report.c8y_IsNavigatorNode) {\n        this.reportDashboardService.removeNavigatorNode(report);\n      }\n      this.reload$.next();\n      this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.REPORTS, {\n        component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.REPORTS_LIST,\n        action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.DELETE,\n        name: report.name,\n        id: report.id,\n        context: PRODUCT_EXPERIENCE.DASHBOARD.CONTEXT.REPORT\n      });\n    } catch (ex) {\n      if (ex) {\n        throw new Error(`Something went wrong: ${ex}`);\n      }\n    }\n  }\n\n  async update(report: IManagedObject) {\n    report.c8y_IsNavigatorNode = report.c8y_IsNavigatorNode ? {} : null;\n    await this.inventoryService.update(report);\n    report.c8y_IsNavigatorNode\n      ? this.reportDashboardService.addReportNavigatorNode(report)\n      : this.reportDashboardService.removeNavigatorNode(report);\n  }\n}\n","<c8y-title>\n  {{ 'Reports' | translate }}\n</c8y-title>\n\n<c8y-action-bar-item\n  [placement]=\"'left'\"\n  itemClass=\"navbar-form\"\n>\n  <div class=\"input-group input-group-search\">\n    <input\n      class=\"form-control\"\n      [attr.aria-label]=\"'Filter' | translate\"\n      placeholder=\"{{ 'Filter…' | translate }}\"\n      type=\"search\"\n      [ngModel]=\"textFilter$ | async\"\n      (ngModelChange)=\"textFilter$.next($event)\"\n    />\n    <span class=\"input-group-addon\">\n      <i\n        c8yIcon=\"search\"\n        *ngIf=\"(textFilter$ | async).length === 0\"\n      ></i>\n      <i\n        class=\"text-muted\"\n        c8yIcon=\"times\"\n        *ngIf=\"(textFilter$ | async).length > 0\"\n        (click)=\"textFilter$.next('')\"\n        px-event=\"Clear filtering reports\"\n      ></i>\n    </span>\n  </div>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Add report' | translate }}\"\n    type=\"button\"\n    [attr.data-cy]=\"'reports-add-report-action-bar-button'\"\n    (click)=\"add()\"\n    [disabled]=\"!canAddReport\"\n  >\n    <i c8yIcon=\"plus-circle\"></i>\n    {{ 'Add report' | translate }}\n  </button>\n  <button\n    class=\"btn btn-dot m-r-16\"\n    aria-label=\"{{ 'Info' | translate }}\"\n    popover=\"{{ 'You don\\'t have permission to add reports' | translate }}\"\n    placement=\"top\"\n    triggers=\"focus\"\n    container=\"body\"\n    type=\"button\"\n    *ngIf=\"!canAddReport\"\n  >\n    <i\n      class=\"text-primary\"\n      [c8yIcon]=\"'info-circle'\"\n    ></i>\n  </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item [placement]=\"'right'\">\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Reload' | translate }}\"\n    type=\"button\"\n    (click)=\"loadReports()\"\n  >\n    <i\n      c8yIcon=\"refresh\"\n      [ngClass]=\"{ 'icon-spin': reloading }\"\n    ></i>\n    {{ 'Reload' | translate }}\n  </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/working-with-reports/#working-with-reports\"></c8y-help>\n\n<c8y-list-group>\n  <c8y-li\n    class=\"page-sticky-header hidden-xs hidden-sm\"\n    *ngIf=\"(reports$ | async)?.data.length > 0\"\n  >\n    <c8y-li-icon>\n      <i class=\"p-l-24\"></i>\n    </c8y-li-icon>\n    <c8y-li-body class=\"content-flex-60\">\n      <div class=\"col-3\">\n        {{ 'Report' | translate }}\n      </div>\n      <div class=\"col-6\">\n        {{ 'Description' | translate }}\n      </div>\n      <div class=\"col-2\">\n        {{ 'Show in navigator' | translate }}\n      </div>\n    </c8y-li-body>\n  </c8y-li>\n\n  <c8y-li *c8yFor=\"let report of reports$; let i = index; loadMore: 'auto'\">\n    <c8y-li-icon [icon]=\"report.icon\"></c8y-li-icon>\n    <c8y-li-body class=\"content-flex-60\">\n      <div class=\"col-3\">\n        <button\n          class=\"btn-clean\"\n          title=\"{{ report.name }}\"\n          type=\"button\"\n          routerLink=\"/reports/{{ report.id }}\"\n        >\n          <span class=\"text-truncate\">\n            {{ report.name }}\n          </span>\n        </button>\n      </div>\n      <div class=\"col-6\">\n        <p class=\"small text-truncate-wrap\">\n          <em\n            class=\"text-muted\"\n            *ngIf=\"!report.description; else showDescription\"\n          >\n            {{ 'No description available' | translate }}\n          </em>\n          <ng-template #showDescription>\n            {{ report.description }}\n          </ng-template>\n        </p>\n      </div>\n      <div class=\"col-2 fit-h-20 m-t-xs-8\">\n        <label\n          class=\"c8y-switch c8y-switch--inline\"\n          title=\"{{ 'Show in navigator' | translate }}\"\n        >\n          <input\n            type=\"checkbox\"\n            [(ngModel)]=\"!!report.c8y_IsNavigatorNode\"\n            (change)=\"update(report)\"\n          />\n          <span></span>\n          <span class=\"visible-xs\">\n            {{ 'Show in navigator' | translate }}\n          </span>\n        </label>\n      </div>\n      <div class=\"col-1 hidden-xs\">\n        <button\n          class=\"btn btn-dot btn-dot--danger showOnHover m-l-auto d-flex\"\n          [attr.aria-label]=\"'Remove report' | translate\"\n          tooltip=\"{{ 'Remove report' | translate }}\"\n          type=\"button\"\n          [delay]=\"500\"\n          (click)=\"delete(report)\"\n        >\n          <i c8yIcon=\"minus-circle\"></i>\n        </button>\n      </div>\n      <div class=\"visible-xs p-t-8 text-right\">\n        <button\n          class=\"btn btn-default btn-sm\"\n          title=\"{{ 'Remove report' | translate }}\"\n          type=\"button\"\n          (click)=\"delete(report)\"\n        >\n          <i c8yIcon=\"delete\"></i>\n          {{ 'Remove report' | translate }}\n        </button>\n      </div>\n    </c8y-li-body>\n  </c8y-li>\n</c8y-list-group>\n\n<c8y-ui-empty-state\n  [icon]=\"'c8y-reports'\"\n  [title]=\"'There are no reports defined.' | translate\"\n  [subtitle]=\"'Add a report first.' | translate\"\n  *ngIf=\"(reports$ | async)?.data.length === 0\"\n>\n  <p>\n    <button\n      class=\"btn btn-primary\"\n      title=\"{{ 'Add report' | translate }}\"\n      type=\"button\"\n      [attr.data-cy]=\"'reports-add-report-empty-state-button'\"\n      [disabled]=\"!canAddReport\"\n      (click)=\"add()\"\n      c8yProductExperience\n      [actionName]=\"PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.REPORTS\"\n      [actionData]=\"{ action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.ADD_REPORT }\"\n    >\n      {{ 'Add report' | translate }}\n    </button>\n  </p>\n  <p c8y-guide-docs>\n    <small\n      translate\n      ngNonBindable\n    >\n      Find out more in the\n      <a c8y-guide-href=\"/docs/cockpit/working-with-reports\">user documentation</a>\n      .\n    </small>\n  </p>\n</c8y-ui-empty-state>\n"]}
@@ -5,4 +5,4 @@
5
5
  */
6
6
  export class ApplicationOptions {
7
7
  }
8
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApplicationOptions.js","sourceRoot":"","sources":["../../../../core/common/ApplicationOptions.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,MAAM,OAAO,kBAAkB;CA+M9B","sourcesContent":["import { IApplication } from '@c8y/client';\n\n/*\n * -----------------------------WARNING---------------------------------\n * This file has an *exact* copy in packages/cli/src/webpack/.\n * Any changes to this file must be reflected there, too.\n */\nexport class ApplicationOptions {\n  /** Application name (saved to the server). */\n  name: string;\n  /** Application context path (saved to the server). */\n  contextPath: string;\n  /** Application key (saved to the server). */\n  key: string;\n  /** The version of the application */\n  version?: string;\n  /** The version of the used WebSDK version */\n  webSdkVersion?: string;\n  /** Set to `true` if the application is hybrid and uses Angular and AngularJS simultaneously. */\n  upgrade?: boolean;\n  /** Path to the branding entry file. (Set it to false to disable any styling. You can handle the styling then on your own e.g. in an angular.json file using ng-cli) */\n  brandingEntry?: string | boolean;\n  /** Path to tsccnfig.json file if TypeScript is used (default: ./tsconfig.json). */\n  tsConfigPath?: string;\n  /** Entry module for Angular compiler (only used with lazy loaded routes), e.g. `'app.module.ts#AppModule'`. */\n  entryModule?: string;\n  /** Path to custom index.html (otherwise default one will be used). */\n  indexTemplate?: string;\n  /** URL to dynamically fetched options. */\n  dynamicOptionsUrl?: string;\n  /** URL to favicon. */\n  faviconUrl?: string;\n  /** URL to *.css file which will replace default branding. */\n  brandingUrl?: string;\n  /** Object with properties that will be converted to CSS custom variables. */\n  brandingCssVars?: BrandingCssVars;\n  /**\n   * Allows for adding or overriding languages available in the application.\n   *\n   * Its keys are language codes and its values are objects with the following properties:\n   *\n   * - `name`: English name of the language,\n   * - `nativeName`: native name of the language,\n   * - `url`: full URL to JSON file with compiled translations;\n   *    if not defined, translations will be loaded from `${localePath}/${langCode}.json`.\n   *\n   * Example:\n   * ```json\n   * \"languages\": {\n   *   \"de\": {\n   *     \"name\": \"German\",\n   *     \"nativeName\": \"Deutsch\",\n   *     \"url\": \"/apps/public/ui-assets/de.json\"\n   *   }\n   * }\n   * ```\n   */\n  languages?: Languages;\n  /**\n   * Allows for adding custom translations. It is an optional property.\n   *\n   * Its keys are language codes (https://cumulocity.com/docs/section/getting_started/#a-name-languages-a-available-languages)\n   * and its values are objects with key-value pairs, where the key is the original string in English and the value - its translation.\n   *\n   * - `Home`: \"Startseite\"\n   *\n   * For example, you can add the translation of your custom cookie banner configured in the branding settings:\n   * ```json\n   * \"i18nExtra\": {\n   *   \"de\": {\n   *     \"About cookies on Cumulocity IoT\": \"Informationen zu Cookies in Cumulocity IoT\",\n   *     \"Click Agree and Proceed to accept cookies and go directly to the platform or click on Privacy Policy to see detailed descriptions of the used cookies.\": \"Klicken Sie auf Zustimmen und fortfahren, um Cookies zu akzeptieren und direkt zur Plattform zu gelangen, oder klicken Sie auf Datenschutzrichtlinie, um detaillierte Beschreibungen der verwendeten Cookies anzuzeigen.\"\n   *   }\n   * }\n   * ```\n   */\n  i18nExtra?: I18nExtra;\n  /** Path to the folder from which *.po files will be loaded. */\n  localePath?: string;\n  /** Array of URLs to additional *.css files to be loaded at runtime. */\n  extraCssUrls?: string[];\n  /** Documentation links settings. */\n  docs?: Docs;\n  /** Application icon to be displayed in app switcher and header bar. */\n  icon?: Icon;\n\n  // These are the old options\n  /** Hide application in app switcher (saved to the server). */\n  noAppSwitcher?: boolean;\n  /** HTML page title. */\n  globalTitle?: string;\n  /** Hide \"powered by\" and version info at the bottom of the navigator and in the right drawer. */\n  hidePowered?: boolean;\n  /** Hides the \"Platform information\" in the right drawer, will overrule the \"hidePowered\" option */\n  hidePlatformInformation?: boolean;\n  /** Shows the link to support page. Accepts values:\n   * false, hide the link\n   * string, value of url to be shown\n   */\n  supportUrl?: boolean | string;\n  /**\n   * Replacement string for `user` field in audit logs for actions performed by a support user\n   * (available placeholders: `{{support_user}}`, `{{supported_user}}`).\n   */\n  supportUserString?: string;\n  /**\n   * Disables realtime updates on the map widget and maps in general.\n   */\n  mapWidgetRealtimeDisabled?: boolean;\n  /**\n   * Allows to adjust the default pagesize of 100 items of the map widget and maps in general.\n   */\n  mapWidgetPageSize?: number;\n  /**\n   * Allows to hide the hint that there are more devices with geo coordinates then displayed on the map widget and maps in general.\n   */\n  mapWidgetHideMaxDeviceOnMapHint?: boolean;\n  /** Enable or disable the right drawer. */\n  rightDrawer?: boolean;\n  /** Enable or disable breadcrumbs in the header for groups and devices (default: false). */\n  breadcrumbs?: boolean;\n  /** Collapse navigator on initial load. */\n  hideNavigator?: boolean;\n  /** Show tabs horizontally or vertically. */\n  tabsHorizontal?: boolean;\n  /** Additional link(s) to display on login screen. */\n  loginExtraLink?: LoginExtraLink | LoginExtraLink[];\n  /** Enable or disable storage limitation feature. */\n  storageLimitationFeatureEnabled?: boolean;\n  /** Name of company handling support requests from app users (displayed in notification message). */\n  companyName?: string;\n  /** URL template for documentation links (default: `'${docsBaseUrl}${partialUrl}'`). */\n  guideHrefTemplate?: string;\n  /** Base URL for documentation links (include `{{ version }}` placeholder, if you want versioned links). */\n  docsBaseUrl?: string;\n  /** CSP string to be applied to `index.html` by replacing default values. */\n  contentSecurityPolicy?: string;\n  /** Enables cloud sensor wizard */\n  sensorPhone?: boolean;\n  /** Show or hide a newsletter subscription checkbox in edit user modal. */\n  newsletter?: boolean;\n  /** Path to the root node_modules dir (useful when working in monorepo setup, e.g. yarn workspaces). */\n  rootNodeModulesPath?: string;\n  /** Cookie Banner configuration */\n  cookieBanner?: CookieBannerConfiguration;\n  /** Cookie preferences configuration. Here you can enable or disable cookie categories */\n  cookiePreferences?: CookiePreferencesConfiguration;\n  /** A key for the product experience software Gainsight. */\n  gainsightKey?: string;\n  /** Disable user tracking */\n  disableTracking?: boolean;\n  /** NgModule export for plugins. */\n  exports?: PluginsExports[];\n  /** List of imported remote plugins. */\n  remotes?: RemotePlugins;\n  /** The package source a application origins from as IApplication or simply the id of the source */\n  source?: string | number | IApplication;\n  /**\n   * Additional assets to copy to the build output.\n   * See https://github.com/webpack-contrib/copy-webpack-plugin for more information\n   * about the patterns to add here.\n   */\n  copy?: [];\n  /**\n   * Allows to enable or disable context help, or to override the default base URL used to load its contents.\n   * By default, the context help uses the same base URL as defined in the `docsBaseUrl` option\n   * (if this option is undefined, then the following value will be used: `https://www.cumulocity.com`).\n   * Alternatively, if a string is provided here, it'll be used as the base URL\n   * and any `{{ version }}` placeholder will be replaced with the relevant docs version.\n   */\n  contextHelp?: boolean | string;\n  /**\n   * By default, cockpit and devicemanagement use the onlyRoots query to resolve root nodes. This\n   * could lead to performance issues, if a customer has a lot of root nodes. Therefore you can disable\n   * the use of this query with this flag.\n   */\n  disableOnlyRootsQuery?: boolean;\n  /**\n   * Allows to force showing the setup wizard.\n   */\n  forceSetup?: boolean;\n  /**\n   * Indicates if the application needs to show the setup wizard.\n   */\n  isSetup?: boolean;\n  /**\n   * By default a WebSDK app requires the user to be logged in.\n   * In case you would like to develop just a static application, that does not require any kind of access to the backend,\n   * you can use this flag to disable the login screen.\n   * NOTE: not all WebSDK components support this, some might require the user to be logged in and won't work.\n   */\n  noLogin?: boolean;\n  /**\n   * Allows to opt out of supporting/loading plugins for this application.\n   */\n  noPlugins?: boolean;\n  /**\n   * Allows to opt out of the version warning which is shown in the dev tools.\n   */\n  noVersionWarning?: boolean;\n  /**\n   * Allows to set the map layers. If not set, defaults to open street map layer.\n   */\n  mapLayers?: MapTileLayer[];\n  /**\n   * Allows to set default configurations on the maps.\n   */\n  mapConfig?: MapDefaultConfig;\n  /**\n   * The URL used to lookup geo coordinates for a user provided address via [nominatim API](https://nominatim.org/release-docs/develop/api/Search/).\n   * Can be set to empty to disable the find address feature on the location tab.\n   * Uses: `https://nominatim.openstreetmap.org/search?format=json&q={searchTerm}` if not set.\n   */\n  mapNominatimUrl?: string;\n}\n\nexport interface MapDefaultConfig {\n  /**\n   * The default zoom level to set on each new map.\n   */\n  zoomLevel?: number;\n  /**\n   * The default center position of each new map.\n   */\n  center?: [number, number];\n}\n\nexport interface MapTileLayer {\n  /**\n   * The layer url in the specific leaflet format.\n   */\n  layerUrl: string;\n  /**\n   * Additional options. Note this options are not typed as leaflet should not be by default included. The type from leaflet is L.TileLayerOptions.\n   */\n  options: any;\n  /**\n   * A label to show to the end user.\n   */\n  label: string;\n  /**\n   * Define the order of the layers to be shown to the user. Highest priority first.\n   */\n  priority?: number;\n}\n\nexport interface RemotePlugins {\n  /**\n   * A key value pair, while the value is an array of modules to load and the\n   * key is the context path.\n   * @example\n   * ```js\n   * {\n   *    'cockpit': ['HomeDashboardModule', 'DataExplorerDashboard'],\n   *    'widget-package@1.0.0': ['ExtendedMapWidget']\n   * }\n   * ``\n   */\n  [key: string]: string[];\n}\n\nexport interface PluginsExports {\n  /**\n   * The name of the Angular module class.\n   */\n  name: string;\n  /**\n   * The file path to the module typescript file.\n   */\n  path: string;\n  /**\n   * An short description about what the module does.\n   */\n  description?: string;\n  /**\n   * Allows to scope the plugin to certain applications. E.g. if you\n   * add here 'cockpit', the plugin can only be installed into an\n   * application on the contextPath `apps/cockpit`. You can use comma\n   * separated values, asterisk (default) to allow all applications or\n   * `self` to limit the plugin to the current solution.\n   */\n  scope?: '*' | 'self' | string;\n}\n\nexport interface CookieBannerConfiguration {\n  /** Here you can set the title of Cookie Banner */\n  cookieBannerTitle?: string;\n  /** Here you can set the Text of Cookie Banner */\n  cookieBannerText?: string;\n  /** Here you can set the policyUrl of Cookie Banner */\n  policyUrl?: string;\n}\n\nexport interface CookiePreferencesConfiguration {\n  /** This category includes e.g. cookies related to logging in  */\n  required?: boolean | string;\n  /** This category includes e.g. tracking cookies  */\n  functional?: boolean | string;\n  /** This category includes e.g. cookies related to advertising  */\n  marketing?: boolean | string;\n}\n\nexport interface LoginExtraLink {\n  url: string;\n  label: string;\n}\n\nexport interface Icon {\n  class?: string;\n  url?: string;\n}\n\nexport interface Docs {\n  /** Hide default links to documentation. */\n  noDefault: boolean;\n  /** List of regex strings. Matching default docs URLs will be hidden. */\n  excludeDefault: string[];\n  /** Additional links to be displayed. */\n  links: Links[];\n}\n\nexport interface Links {\n  /** Icon classes with `c8y-icon`, e.g. `c8y-icon c8y-icon-add-user` or `c8y-icon c8y-icon-device-connect`. */\n  icon: string;\n  label: string;\n  url: string;\n  type: 'doc' | 'quicklink';\n}\n\nexport interface I18nExtra {\n  [langCode: string]: I18nExtraLangCode;\n}\n\nexport interface I18nExtraLangCode {\n  [key: string]: string;\n}\n\nexport interface Languages {\n  [langCode: string]: LanguagesLangCode;\n}\n\nexport interface LanguagesLangCode {\n  name: string;\n  nativeName: string;\n  url: string;\n}\n\nexport interface BrandingCssVars {\n  [key: string]: string;\n}\n"]}
8
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApplicationOptions.js","sourceRoot":"","sources":["../../../../core/common/ApplicationOptions.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,MAAM,OAAO,kBAAkB;CA+M9B","sourcesContent":["import { IApplication } from '@c8y/client';\n\n/*\n * -----------------------------WARNING---------------------------------\n * This file has an *exact* copy in packages/cli/src/webpack/.\n * Any changes to this file must be reflected there, too.\n */\nexport class ApplicationOptions {\n  /** Application name (saved to the server). */\n  name: string;\n  /** Application context path (saved to the server). */\n  contextPath: string;\n  /** Application key (saved to the server). */\n  key: string;\n  /** The version of the application */\n  version?: string;\n  /** The version of the used WebSDK version */\n  webSdkVersion?: string;\n  /** Set to `true` if the application is hybrid and uses Angular and AngularJS simultaneously. */\n  upgrade?: boolean;\n  /** Path to the branding entry file. (Set it to false to disable any styling. You can handle the styling then on your own e.g. in an angular.json file using ng-cli) */\n  brandingEntry?: string | boolean;\n  /** Path to tsccnfig.json file if TypeScript is used (default: ./tsconfig.json). */\n  tsConfigPath?: string;\n  /** Entry module for Angular compiler (only used with lazy loaded routes), e.g. `'app.module.ts#AppModule'`. */\n  entryModule?: string;\n  /** Path to custom index.html (otherwise default one will be used). */\n  indexTemplate?: string;\n  /** URL to dynamically fetched options. */\n  dynamicOptionsUrl?: string;\n  /** URL to favicon. */\n  faviconUrl?: string;\n  /** URL to *.css file which will replace default branding. */\n  brandingUrl?: string;\n  /** Object with properties that will be converted to CSS custom variables. */\n  brandingCssVars?: BrandingCssVars;\n  /**\n   * Allows for adding or overriding languages available in the application.\n   *\n   * Its keys are language codes and its values are objects with the following properties:\n   *\n   * - `name`: English name of the language,\n   * - `nativeName`: native name of the language,\n   * - `url`: full URL to JSON file with compiled translations;\n   *    if not defined, translations will be loaded from `${localePath}/${langCode}.json`.\n   *\n   * Example:\n   * ```json\n   * \"languages\": {\n   *   \"de\": {\n   *     \"name\": \"German\",\n   *     \"nativeName\": \"Deutsch\",\n   *     \"url\": \"/apps/public/ui-assets/de.json\"\n   *   }\n   * }\n   * ```\n   */\n  languages?: Languages;\n  /**\n   * Allows for adding custom translations. It is an optional property.\n   *\n   * Its keys are language codes (https://cumulocity.com/docs/section/getting_started/#a-name-languages-a-available-languages)\n   * and its values are objects with key-value pairs, where the key is the original string in English and the value - its translation.\n   *\n   * - `Home`: \"Startseite\"\n   *\n   * For example, you can add the translation of your custom cookie banner configured in the branding settings:\n   * ```json\n   * \"i18nExtra\": {\n   *   \"de\": {\n   *     \"About cookies on Cumulocity IoT\": \"Informationen zu Cookies in Cumulocity IoT\",\n   *     \"Click Agree and Proceed to accept cookies and go directly to the platform or click on Privacy Policy to see detailed descriptions of the used cookies.\": \"Klicken Sie auf Zustimmen und fortfahren, um Cookies zu akzeptieren und direkt zur Plattform zu gelangen, oder klicken Sie auf Datenschutzrichtlinie, um detaillierte Beschreibungen der verwendeten Cookies anzuzeigen.\"\n   *   }\n   * }\n   * ```\n   */\n  i18nExtra?: I18nExtra;\n  /** Path to the folder from which *.po files will be loaded. */\n  localePath?: string;\n  /** Array of URLs to additional *.css files to be loaded at runtime. */\n  extraCssUrls?: string[];\n  /** Documentation links settings. */\n  docs?: Docs;\n  /** Application icon to be displayed in app switcher and header bar. */\n  icon?: Icon;\n\n  // These are the old options\n  /** Hide application in app switcher (saved to the server). */\n  noAppSwitcher?: boolean;\n  /** HTML page title. */\n  globalTitle?: string;\n  /** Hide \"powered by\" and version info at the bottom of the navigator and in the right drawer. */\n  hidePowered?: boolean;\n  /** Hides the \"Platform information\" in the right drawer, will overrule the \"hidePowered\" option */\n  hidePlatformInformation?: boolean;\n  /** Shows the link to support page. Accepts values:\n   * false, hide the link\n   * string, value of url to be shown\n   */\n  supportUrl?: boolean | string;\n  /**\n   * Replacement string for `user` field in audit logs for actions performed by a support user\n   * (available placeholders: `{{support_user}}`, `{{supported_user}}`).\n   */\n  supportUserString?: string;\n  /**\n   * Disables realtime updates on the map widget and maps in general.\n   */\n  mapWidgetRealtimeDisabled?: boolean;\n  /**\n   * Allows to adjust the default pagesize of 100 items of the map widget and maps in general.\n   */\n  mapWidgetPageSize?: number;\n  /**\n   * Allows to hide the hint that there are more devices with geo coordinates then displayed on the map widget and maps in general.\n   */\n  mapWidgetHideMaxDeviceOnMapHint?: boolean;\n  /** Enable or disable the right drawer. */\n  rightDrawer?: boolean;\n  /** Enable or disable breadcrumbs in the header for groups and devices (default: false). */\n  breadcrumbs?: boolean;\n  /** Collapse navigator on initial load. */\n  hideNavigator?: boolean;\n  /** Show tabs horizontally or vertically. */\n  tabsHorizontal?: boolean;\n  /** Additional link(s) to display on login screen. */\n  loginExtraLink?: LoginExtraLink | LoginExtraLink[];\n  /** Enable or disable storage limitation feature. */\n  storageLimitationFeatureEnabled?: boolean;\n  /** Name of company handling support requests from app users (displayed in notification message). */\n  companyName?: string;\n  /** URL template for documentation links (default: `'${docsBaseUrl}${partialUrl}'`). */\n  guideHrefTemplate?: string;\n  /** Base URL for documentation links (include `{{ version }}` placeholder, if you want versioned links). */\n  docsBaseUrl?: string;\n  /** CSP string to be applied to `index.html` by replacing default values. */\n  contentSecurityPolicy?: string;\n  /** Enables cloud sensor wizard */\n  sensorPhone?: boolean;\n  /** Show or hide a newsletter subscription checkbox in edit user modal. */\n  newsletter?: boolean;\n  /** Path to the root node_modules dir (useful when working in monorepo setup, e.g. yarn workspaces). */\n  rootNodeModulesPath?: string;\n  /** Cookie Banner configuration */\n  cookieBanner?: CookieBannerConfiguration;\n  /** Cookie preferences configuration. Here you can enable or disable cookie categories */\n  cookiePreferences?: CookiePreferencesConfiguration;\n  /** A key for the product experience software Gainsight. */\n  gainsightKey?: string;\n  /** Disable user tracking */\n  disableTracking?: boolean;\n  /** NgModule export for plugins. */\n  exports?: PluginsExports[];\n  /** List of imported remote plugins. */\n  remotes?: RemotePlugins;\n  /** The package source a application origins from as IApplication or simply the id of the source */\n  source?: string | number | IApplication;\n  /**\n   * Additional assets to copy to the build output.\n   * See https://github.com/webpack-contrib/copy-webpack-plugin for more information\n   * about the patterns to add here.\n   */\n  copy?: [];\n  /**\n   * Allows to enable or disable context help, or to override the default base URL used to load its contents.\n   * By default, the context help uses the same base URL as defined in the `docsBaseUrl` option\n   * (if this option is undefined, then the following value will be used: `https://cumulocity.com/guides/{{version}}`).\n   * Alternatively, if a string is provided here, it'll be used as the base URL\n   * and any `{{ version }}` placeholder will be replaced with the relevant docs version.\n   */\n  contextHelp?: boolean | string;\n  /**\n   * By default, cockpit and devicemanagement use the onlyRoots query to resolve root nodes. This\n   * could lead to performance issues, if a customer has a lot of root nodes. Therefore you can disable\n   * the use of this query with this flag.\n   */\n  disableOnlyRootsQuery?: boolean;\n  /**\n   * Allows to force showing the setup wizard.\n   */\n  forceSetup?: boolean;\n  /**\n   * Indicates if the application needs to show the setup wizard.\n   */\n  isSetup?: boolean;\n  /**\n   * By default a WebSDK app requires the user to be logged in.\n   * In case you would like to develop just a static application, that does not require any kind of access to the backend,\n   * you can use this flag to disable the login screen.\n   * NOTE: not all WebSDK components support this, some might require the user to be logged in and won't work.\n   */\n  noLogin?: boolean;\n  /**\n   * Allows to opt out of supporting/loading plugins for this application.\n   */\n  noPlugins?: boolean;\n  /**\n   * Allows to opt out of the version warning which is shown in the dev tools.\n   */\n  noVersionWarning?: boolean;\n  /**\n   * Allows to set the map layers. If not set, defaults to open street map layer.\n   */\n  mapLayers?: MapTileLayer[];\n  /**\n   * Allows to set default configurations on the maps.\n   */\n  mapConfig?: MapDefaultConfig;\n  /**\n   * The URL used to lookup geo coordinates for a user provided address via [nominatim API](https://nominatim.org/release-docs/develop/api/Search/).\n   * Can be set to empty to disable the find address feature on the location tab.\n   * Uses: `https://nominatim.openstreetmap.org/search?format=json&q={searchTerm}` if not set.\n   */\n  mapNominatimUrl?: string;\n}\n\nexport interface MapDefaultConfig {\n  /**\n   * The default zoom level to set on each new map.\n   */\n  zoomLevel?: number;\n  /**\n   * The default center position of each new map.\n   */\n  center?: [number, number];\n}\n\nexport interface MapTileLayer {\n  /**\n   * The layer url in the specific leaflet format.\n   */\n  layerUrl: string;\n  /**\n   * Additional options. Note this options are not typed as leaflet should not be by default included. The type from leaflet is L.TileLayerOptions.\n   */\n  options: any;\n  /**\n   * A label to show to the end user.\n   */\n  label: string;\n  /**\n   * Define the order of the layers to be shown to the user. Highest priority first.\n   */\n  priority?: number;\n}\n\nexport interface RemotePlugins {\n  /**\n   * A key value pair, while the value is an array of modules to load and the\n   * key is the context path.\n   * @example\n   * ```js\n   * {\n   *    'cockpit': ['HomeDashboardModule', 'DataExplorerDashboard'],\n   *    'widget-package@1.0.0': ['ExtendedMapWidget']\n   * }\n   * ``\n   */\n  [key: string]: string[];\n}\n\nexport interface PluginsExports {\n  /**\n   * The name of the Angular module class.\n   */\n  name: string;\n  /**\n   * The file path to the module typescript file.\n   */\n  path: string;\n  /**\n   * An short description about what the module does.\n   */\n  description?: string;\n  /**\n   * Allows to scope the plugin to certain applications. E.g. if you\n   * add here 'cockpit', the plugin can only be installed into an\n   * application on the contextPath `apps/cockpit`. You can use comma\n   * separated values, asterisk (default) to allow all applications or\n   * `self` to limit the plugin to the current solution.\n   */\n  scope?: '*' | 'self' | string;\n}\n\nexport interface CookieBannerConfiguration {\n  /** Here you can set the title of Cookie Banner */\n  cookieBannerTitle?: string;\n  /** Here you can set the Text of Cookie Banner */\n  cookieBannerText?: string;\n  /** Here you can set the policyUrl of Cookie Banner */\n  policyUrl?: string;\n}\n\nexport interface CookiePreferencesConfiguration {\n  /** This category includes e.g. cookies related to logging in  */\n  required?: boolean | string;\n  /** This category includes e.g. tracking cookies  */\n  functional?: boolean | string;\n  /** This category includes e.g. cookies related to advertising  */\n  marketing?: boolean | string;\n}\n\nexport interface LoginExtraLink {\n  url: string;\n  label: string;\n}\n\nexport interface Icon {\n  class?: string;\n  url?: string;\n}\n\nexport interface Docs {\n  /** Hide default links to documentation. */\n  noDefault: boolean;\n  /** List of regex strings. Matching default docs URLs will be hidden. */\n  excludeDefault: string[];\n  /** Additional links to be displayed. */\n  links: Links[];\n}\n\nexport interface Links {\n  /** Icon classes with `c8y-icon`, e.g. `c8y-icon c8y-icon-add-user` or `c8y-icon c8y-icon-device-connect`. */\n  icon: string;\n  label: string;\n  url: string;\n  type: 'doc' | 'quicklink';\n}\n\nexport interface I18nExtra {\n  [langCode: string]: I18nExtraLangCode;\n}\n\nexport interface I18nExtraLangCode {\n  [key: string]: string;\n}\n\nexport interface Languages {\n  [langCode: string]: LanguagesLangCode;\n}\n\nexport interface LanguagesLangCode {\n  name: string;\n  nativeName: string;\n  url: string;\n}\n\nexport interface BrandingCssVars {\n  [key: string]: string;\n}\n"]}