@c8y/ngx-components 1021.22.27 → 1021.22.30

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.
@@ -1 +1 @@
1
- {"version":3,"file":"alarms-view.service.d.ts","sourceRoot":"","sources":["../../alarms/alarms-view.service.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,gBAAgB,EAChB,YAAY,EAGZ,MAAM,EACN,WAAW,EAEX,cAAc,EACd,YAAY,EACb,MAAM,aAAa,CAAC;AACrB,OAAO,EACL,kBAAkB,EAClB,WAAW,EACX,eAAe,EACf,cAAc,EAGf,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAmB,UAAU,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAC;;AAE1E;;;;;;;;GAQG;AACH,qBAGa,iBAAiB;IAa1B,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,cAAc;IAbxB,QAAQ,CAAC,sBAAsB,EAAE,MAAM,kBAAkB,CAAuB;IAChF,QAAQ,CAAC,sBAAsB,SAAU;IACzC,QAAQ,CAAC,4BAA4B,cAAc;IACnD,QAAQ,CAAC,uBAAuB,WAA2C;IAC3E,QAAQ,CAAC,8BAA8B,4CAAsD;IAE7F,kBAAkB,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IACxC,iBAAiB,gBAAuB;IAExC,OAAO,CAAC,kBAAkB,CAA2B;gBAG3C,YAAY,EAAE,YAAY,EAC1B,cAAc,EAAE,cAAc;IAQxC;;OAEG;IACH,eAAe,IAAI,IAAI;IAIvB;;;;;;;;;OASG;IACH,sBAAsB,CACpB,UAAU,EAAE,YAAY,EAAE,EAC1B,WAAW,UAAQ,EACnB,aAAa,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,EAC5B,MAAM,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAkB/B,oBAAoB,CAAC,KAAK,EAAE,eAAe;IAS3C;;;OAGG;IACH,mBAAmB,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAIzC;;;;;;;;;OASG;IACG,wBAAwB,CAC5B,QAAQ,EAAE,YAAY,EACtB,WAAW,EAAE,OAAO,EACpB,MAAM,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC,MAAM,CAAC;IAYlB;;;;;OAKG;IACH,iBAAiB,IAAI,OAAO;IAK5B;;;;;;OAMG;IACH,wBAAwB,CAAC,eAAe,EAAE,cAAc,GAAG,YAAY,EAAE;IAMzE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;IACG,oBAAoB,CACxB,kBAAkB,EAAE,YAAY,EAAE,EAClC,QAAQ,EAAE,MAAM,GAAG,MAAM,GACxB,OAAO,CAAC;QAAE,mBAAmB,EAAE,OAAO,CAAA;KAAE,CAAC;IAwB5C;;;;;OAKG;IACH,aAAa,CAAC,WAAW,CAAC,EAAE,WAAW,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM;IAmBhE;;;;;OAKG;IACH,wBAAwB,CAAC,WAAW,CAAC,EAAE,WAAW,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE;IAI7E;;;;OAIG;IACH,4BAA4B,CAAC,UAAU,EAAE,mBAAmB,CAAC,IAAI,CAAC,GAAG,eAAe;IAWpF;;;;;;;;OAQG;IACH,OAAO,CAAC,yBAAyB;IAWjC;;;;;;;OAOG;IACH,OAAO,CAAC,uBAAuB;yCAzQpB,iBAAiB;6CAAjB,iBAAiB;CAgR7B"}
1
+ {"version":3,"file":"alarms-view.service.d.ts","sourceRoot":"","sources":["../../alarms/alarms-view.service.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,gBAAgB,EAChB,YAAY,EAGZ,MAAM,EACN,WAAW,EAEX,cAAc,EACd,YAAY,EACb,MAAM,aAAa,CAAC;AACrB,OAAO,EACL,kBAAkB,EAClB,WAAW,EACX,eAAe,EACf,cAAc,EAGf,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAmB,UAAU,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAC;;AAE1E;;;;;;;;GAQG;AACH,qBAGa,iBAAiB;IAa1B,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,cAAc;IAbxB,QAAQ,CAAC,sBAAsB,EAAE,MAAM,kBAAkB,CAAuB;IAChF,QAAQ,CAAC,sBAAsB,SAAU;IACzC,QAAQ,CAAC,4BAA4B,cAAc;IACnD,QAAQ,CAAC,uBAAuB,WAA2C;IAC3E,QAAQ,CAAC,8BAA8B,4CAAsD;IAE7F,kBAAkB,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IACxC,iBAAiB,gBAAuB;IAExC,OAAO,CAAC,kBAAkB,CAA2B;gBAG3C,YAAY,EAAE,YAAY,EAC1B,cAAc,EAAE,cAAc;IAQxC;;OAEG;IACH,eAAe,IAAI,IAAI;IAIvB;;;;;;;;;OASG;IACH,sBAAsB,CACpB,UAAU,EAAE,YAAY,EAAE,EAC1B,WAAW,UAAQ,EACnB,aAAa,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,EAC5B,MAAM,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAkB/B,oBAAoB,CAAC,KAAK,EAAE,eAAe;IAS3C;;;OAGG;IACH,mBAAmB,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAIzC;;;;;;;;;OASG;IACG,wBAAwB,CAC5B,QAAQ,EAAE,YAAY,EACtB,WAAW,EAAE,OAAO,EACpB,MAAM,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC,MAAM,CAAC;IAYlB;;;;;OAKG;IACH,iBAAiB,IAAI,OAAO;IAK5B;;;;;;OAMG;IACH,wBAAwB,CAAC,eAAe,EAAE,cAAc,GAAG,YAAY,EAAE;IAMzE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;IACG,oBAAoB,CACxB,kBAAkB,EAAE,YAAY,EAAE,EAClC,QAAQ,EAAE,MAAM,GAAG,MAAM,GACxB,OAAO,CAAC;QAAE,mBAAmB,EAAE,OAAO,CAAA;KAAE,CAAC;IAwB5C;;;;;OAKG;IACH,aAAa,CAAC,WAAW,CAAC,EAAE,WAAW,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM;IAqBhE;;;;;OAKG;IACH,wBAAwB,CAAC,WAAW,CAAC,EAAE,WAAW,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE;IAI7E;;;;OAIG;IACH,4BAA4B,CAAC,UAAU,EAAE,mBAAmB,CAAC,IAAI,CAAC,GAAG,eAAe;IAWpF;;;;;;;;OAQG;IACH,OAAO,CAAC,yBAAyB;IAWjC;;;;;;;OAOG;IACH,OAAO,CAAC,uBAAuB;yCA3QpB,iBAAiB;6CAAjB,iBAAiB;CAkR7B"}
@@ -96,6 +96,8 @@ export interface CustomColumnConfig extends ColumnConfig {
96
96
  export interface Filter {
97
97
  /** Custom filtering form renderer can set any value here and it can be used to build a query to the server. */
98
98
  externalFilterQuery?: any;
99
+ /** An optional property that holds a string to search for. */
100
+ filterPredicate?: string | FilterPredicateFunction;
99
101
  }
100
102
  /** Describes an object with data grid configuration. */
101
103
  export interface GridConfig {
@@ -1 +1 @@
1
- {"version":3,"file":"data-grid.model.d.ts","sourceRoot":"","sources":["../../../core/data-grid/data-grid.model.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"data-grid.model.d.ts","sourceRoot":"","sources":["../../../core/data-grid/data-grid.model.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"data-grid.service.d.ts","sourceRoot":"","sources":["../../../core/data-grid/data-grid.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE1C,OAAO,EAAsB,UAAU,EAAM,MAAM,MAAM,CAAC;AAE1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,qDAAqD,CAAC;AAE7F,OAAO,EAAE,MAAM,EAAsB,UAAU,EAAE,MAAM,mBAAmB,CAAC;;AAE3E,qBAGa,eAAe;IAKd,SAAS,CAAC,sBAAsB,EAAE,sBAAsB;IAJpE,SAAS,CAAC,iBAAiB,SAAM;IAEjC,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC;gBAEb,sBAAsB,EAAE,sBAAsB;IAIpE,WAAW,CAAC,GAAG,EAAE,MAAM;IAIvB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU,CAAC,UAAU,CAAC;IAY/C,WAAW,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,GAAG,UAAU,CAAC,UAAU,CAAC;IAIpE,yBAAyB,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,UAAU,CAAC,EAAE,MAAM;IAWvF,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,aAAa,KAAK,GAAG,GAAG;IAQvD,oBAAoB,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE;IAgC1F,OAAO,CAAC,mBAAmB;yCAhFhB,eAAe;6CAAf,eAAe;CAyG3B"}
1
+ {"version":3,"file":"data-grid.service.d.ts","sourceRoot":"","sources":["../../../core/data-grid/data-grid.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE1C,OAAO,EAAsB,UAAU,EAAM,MAAM,MAAM,CAAC;AAE1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,qDAAqD,CAAC;AAE7F,OAAO,EAAE,MAAM,EAAsB,UAAU,EAAE,MAAM,mBAAmB,CAAC;;AAE3E,qBAGa,eAAe;IAKd,SAAS,CAAC,sBAAsB,EAAE,sBAAsB;IAJpE,SAAS,CAAC,iBAAiB,SAAM;IAEjC,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC;gBAEb,sBAAsB,EAAE,sBAAsB;IAIpE,WAAW,CAAC,GAAG,EAAE,MAAM;IAIvB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU,CAAC,UAAU,CAAC;IAY/C,WAAW,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,GAAG,UAAU,CAAC,UAAU,CAAC;IAIpE,yBAAyB,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,UAAU,CAAC,EAAE,MAAM;IAWvF,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,aAAa,KAAK,GAAG,GAAG;IAQvD,oBAAoB,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE;IAmC1F,OAAO,CAAC,mBAAmB;yCAnFhB,eAAe;6CAAf,eAAe;CA4G3B"}
@@ -187,6 +187,8 @@ export class AlarmsViewService {
187
187
  return `/device/${contextData.contextData.id}${detailUrl}`;
188
188
  case ViewContext.Group:
189
189
  return `/group/${contextData.contextData.id}${detailUrl}`;
190
+ case ViewContext.Simulators:
191
+ return `/simulators/${contextData.contextData.id}${detailUrl}`;
190
192
  default:
191
193
  return detailUrl;
192
194
  }
@@ -256,4 +258,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
256
258
  providedIn: 'root'
257
259
  }]
258
260
  }], ctorParameters: () => [{ type: i1.AlarmService }, { type: i2.OptionsService }] });
259
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarms-view.service.js","sourceRoot":"","sources":["../../../alarms/alarms-view.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  ALARM_STATUS_LABELS,\n  AlarmQueryFilter,\n  AlarmService,\n  AlarmStatus,\n  AlarmStatusType,\n  IAlarm,\n  IResultList,\n  Severity,\n  SeverityFilter,\n  SeverityType\n} from '@c8y/client';\nimport {\n  ApplicationOptions,\n  ContextData,\n  DateTimeContext,\n  OptionsService,\n  ViewContext,\n  gettext\n} from '@c8y/ngx-components';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport { ALARMS_PATH, INTERVALS_EXTENDED } from './alarms.model';\nimport { AlarmFilterInterval } from '@c8y/ngx-components/interval-picker';\n\n/**\n * Service for managing and retrieving alarms data within the alarms view.\n *\n * The `AlarmsViewService` provides functionality to interact with alarms,\n * including filtering, counting, and translation-related operations in an alarms view.\n *\n * This service relies on the `AlarmService` for fetching alarm data and the `OptionsService`\n * for configuring alarms view options.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class AlarmsViewService {\n  readonly ALARM_REFRESH_TYPE_KEY: keyof ApplicationOptions = 'alarmsRefreshType';\n  readonly DEFAULT_INTERVAL_VALUE = 30_000;\n  readonly DEFAULT_REFRESH_OPTION_VALUE = 'interval';\n  readonly DEFAULT_INTERVAL_VALUES = [5_000, 10_000, 15_000, 30_000, 60_000];\n  readonly REALTIME_UPDATE_ALARMS_MESSAGE = gettext('The list was updated, click to refresh.');\n\n  isIntervalEnabled$: Observable<boolean>;\n  reloadAlarmsList$ = new Subject<void>();\n\n  private _isIntervalEnabled: BehaviorSubject<boolean>;\n\n  constructor(\n    private alarmService: AlarmService,\n    private optionsService: OptionsService\n  ) {\n    if (this.isIntervalRefresh()) {\n      this._isIntervalEnabled = new BehaviorSubject<boolean>(true);\n      this.isIntervalEnabled$ = this._isIntervalEnabled.asObservable();\n    }\n  }\n\n  /**\n   * Emits a subject to initialize the alarms reloading.\n   */\n  updateAlarmList(): void {\n    this.reloadAlarmsList$.next();\n  }\n\n  /**\n   * Retrieves a list of alarms filtered by specified severities and other optional query filters.\n   *\n   * @param severities an array of severities to filter the alarms.\n   * @param showCleared flag indicating whether to show cleared alarms. Defaults to false.\n   * @param selectedDates an array of two dates to filter alarms by creation and last update dates.\n   * @param filter additional query filters for retrieving alarms.\n   *\n   * @returns A promise that resolves to a list of alarms satisfying the specified filters.\n   */\n  retrieveFilteredAlarms(\n    severities: SeverityType[],\n    showCleared = false,\n    selectedDates?: [Date, Date],\n    filter?: AlarmQueryFilter\n  ): Promise<IResultList<IAlarm>> {\n    const severitiesQuery = this.getSeverityQueryParameter(severities);\n    const statusesQuery = this.getStatusQueryParameter(showCleared);\n\n    const _filter: AlarmQueryFilter = {\n      pageSize: 50,\n      withTotalPages: true,\n      ...(severitiesQuery && { severity: severitiesQuery }),\n      ...(statusesQuery && { status: statusesQuery }),\n      ...(selectedDates && {\n        lastUpdatedFrom: selectedDates[0].toISOString(),\n        createdTo: selectedDates[1].toISOString()\n      }),\n      ...filter\n    };\n    return this.alarmService.list(_filter);\n  }\n\n  retrieveAlarmsByDate(dates: DateTimeContext) {\n    return this.alarmService.list({\n      lastUpdatedFrom: dates[0].toISOString(),\n      createdTo: dates[1].toISOString(),\n      pageSize: 50,\n      withTotalPages: true\n    });\n  }\n\n  /**\n   * Updates the state to enable or disable intervals.\n   * @param value - A boolean value to indicate whether to enable intervals.\n   */\n  updateIntervalState(value: boolean): void {\n    this._isIntervalEnabled?.next(value);\n  }\n\n  /**\n   * Fetches the count of alarms filtered by severity and clearance status.\n   *\n   * @param severity - The severity level to filter by (e.g., CRITICAL, MAJOR, etc.).\n   * @param showCleared - Whether or not to include cleared alarms in the count.\n   * @param filter - Additional filter criteria for alarms.\n   *\n   * @returns A promise that resolves to the number of alarms that match the filter criteria.\n   *\n   */\n  async getAlarmsCountBySeverity(\n    severity: SeverityType,\n    showCleared: boolean,\n    filter?: AlarmQueryFilter\n  ): Promise<number> {\n    const statusesQuery = this.getStatusQueryParameter(showCleared);\n    const _filter: AlarmQueryFilter = {\n      ...(severity && { severity: severity }),\n      ...(statusesQuery && { status: statusesQuery }),\n      ...filter\n    };\n    const { data } = await this.alarmService.count(_filter);\n\n    return data;\n  }\n\n  /**\n   * Retrieves the current alarms refresh type from the OptionsService\n   * and determines whether it is set to \"interval\".\n   *\n   * @returns `true` if the alarms refresh type is \"interval,\" otherwise `false`.\n   */\n  isIntervalRefresh(): boolean {\n    const value = this.optionsService.get(this.ALARM_REFRESH_TYPE_KEY, 'interval');\n    return value === 'interval';\n  }\n\n  /**\n   * Updates the list of selected severities based on the new severity filter.\n   *\n   * @param severityUpdates - The object representing the updates to each severity.\n   *\n   * @returns An array representing the updated selected severities.\n   */\n  updateSelectedSeverities(severityUpdates: SeverityFilter): SeverityType[] {\n    return (Object.keys(severityUpdates) as SeverityType[])\n      .filter(key => severityUpdates[key])\n      .map(key => key.toUpperCase() as SeverityType);\n  }\n\n  /**\n   * Clears all active alarms of the selected severities.\n   *\n   * This method clears all active alarms for the given list of severities by making bulk update calls. If no severities are selected, it defaults to using all available severities.\n   * It works by sending a series of update requests for each severity and returns a Promise that resolves with an object indicating if all alarms were resolved immediately.\n   *\n   * @param selectedSeverities An array of severities to be cleared. If not provided, all severities will be cleared.\n   * @param sourceId - Identifier for the source associated with the alarms to be cleared.\n   *\n   * @returns A Promise that resolves with an object with a flag `resolvedImmediately`. The flag is true if all alarms for all selected severities were cleared successfully; otherwise false.\n   *\n   * **Example**\n   * ```typescript\n   * const severitiesToClear: SeverityType[] = [Severity.MAJOR, Severity.MINOR];\n   *\n   * clearAllActiveAlarms(severitiesToClear).then(({ resolvedImmediately }) => {\n   *   if (resolvedImmediately) {\n   *     console.log('All selected alarms were cleared successfully.');\n   *   } else {\n   *     console.log('Some alarms could not be cleared.');\n   *   }\n   * });\n   * ```\n   *\n   * **Note**\n   * - The method uses the `alarmService.updateBulk` for each severity to clear the active alarms.\n   * - It may fetch the `sourceId` based on the view (if applicable) and include it as a query parameter in the update calls.\n   * - The method returns immediately but the returned Promise needs to have a `then` or `catch` method call to handle the result or error respectively.\n   * - Uses `Promise.all` to wait for all update requests to complete before resolving the final result.\n   */\n  async clearAllActiveAlarms(\n    selectedSeverities: SeverityType[],\n    sourceId: string | number\n  ): Promise<{ resolvedImmediately: boolean }> {\n    const severitiesToUpdate = selectedSeverities || Severity;\n\n    const promises = Object.values(severitiesToUpdate).map((severity: SeverityType) => {\n      const commonParams = { resolved: false, severity };\n\n      const parameters = sourceId\n        ? {\n            ...commonParams,\n            source: sourceId,\n            withSourceAssets: true,\n            withSourceDevices: true\n          }\n        : commonParams;\n\n      return this.alarmService.updateBulk({ status: AlarmStatus.CLEARED }, parameters);\n    });\n\n    const responses = await Promise.all(promises);\n    return {\n      resolvedImmediately: responses.every(res => res)\n    };\n  }\n\n  /**\n   * Returns the correct link based on the provided context data.\n   * @param contextData The context the navigation was triggered from.\n   * @param alarm The alarm to navigate to.\n   * @returns A link to be used as an url navigation.\n   */\n  getRouterLink(contextData?: ContextData, alarm?: IAlarm): string {\n    let detailUrl = `/${ALARMS_PATH}`;\n    if (alarm) {\n      detailUrl = `/${ALARMS_PATH}/${alarm.id}`;\n    }\n    if (!contextData) {\n      return detailUrl;\n    }\n\n    switch (contextData.context) {\n      case ViewContext.Device:\n        return `/device/${contextData.contextData.id}${detailUrl}`;\n      case ViewContext.Group:\n        return `/group/${contextData.contextData.id}${detailUrl}`;\n      default:\n        return detailUrl;\n    }\n  }\n\n  /**\n   * Returns the correct array navigation.\n   * @param contextData The context the navigation was triggered from.\n   * @param alarm The alarm to navigate to.\n   * @returns A link to be used as a router.navigation.\n   */\n  getRouterNavigationArray(contextData?: ContextData, alarm?: IAlarm): string[] {\n    return this.getRouterLink(contextData, alarm).split('/').filter(Boolean);\n  }\n\n  /**\n   * Returns the correct from and to dates based on the selected interval\n   * @param intervalId the selected interval. E.g. 'none', 'hours', 'custom' ...\n   * @returns The calculated date context based on the selected interval.\n   */\n  getDateTimeContextByInterval(intervalId: AlarmFilterInterval['id']): DateTimeContext {\n    const interval = INTERVALS_EXTENDED.find(({ id }) => id === intervalId);\n    if (interval.id === 'none') {\n      return [new Date(0), new Date()];\n    }\n\n    const dateTo = new Date();\n    const dateFrom = new Date(dateTo.valueOf() - interval.timespanInMs);\n    return [dateFrom, dateTo];\n  }\n\n  /**\n   * Creates a value for query parameter for filtering alarms by severity based on array of selected severities.\n   *\n   * @param severities - An array of alarm severity types to include in the filter.\n   * If the array is empty or undefined, no severity filter will be applied.\n   *\n   * @returns A comma-separated string of selected alarm severities,\n   * or null if no severities are provided.\n   */\n  private getSeverityQueryParameter(severities: SeverityType[]): string | null {\n    if (!severities || severities.length === 0) {\n      return;\n    }\n    if (severities.length === Object.keys(Severity).length) {\n      return;\n    }\n\n    return severities.join(',');\n  }\n\n  /**\n   * Creates a value for query parameter for filtering alarms by statuses based on showCleared option.\n   *\n   * @param showCleared - A flag indicating whether to include cleared statuses.\n   * If true, all statuses, including 'CLEARED', will be included; if false, 'CLEARED' will be excluded.\n   *\n   * @returns A comma-separated string of alarm statuses.\n   */\n  private getStatusQueryParameter(showCleared: boolean): string {\n    const statuses = Object.keys(ALARM_STATUS_LABELS) as AlarmStatusType[];\n    const filteredStatuses = showCleared\n      ? statuses\n      : statuses.filter(status => status !== 'CLEARED');\n    return filteredStatuses.join(',');\n  }\n}\n"]}
261
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarms-view.service.js","sourceRoot":"","sources":["../../../alarms/alarms-view.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  ALARM_STATUS_LABELS,\n  AlarmQueryFilter,\n  AlarmService,\n  AlarmStatus,\n  AlarmStatusType,\n  IAlarm,\n  IResultList,\n  Severity,\n  SeverityFilter,\n  SeverityType\n} from '@c8y/client';\nimport {\n  ApplicationOptions,\n  ContextData,\n  DateTimeContext,\n  OptionsService,\n  ViewContext,\n  gettext\n} from '@c8y/ngx-components';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport { ALARMS_PATH, INTERVALS_EXTENDED } from './alarms.model';\nimport { AlarmFilterInterval } from '@c8y/ngx-components/interval-picker';\n\n/**\n * Service for managing and retrieving alarms data within the alarms view.\n *\n * The `AlarmsViewService` provides functionality to interact with alarms,\n * including filtering, counting, and translation-related operations in an alarms view.\n *\n * This service relies on the `AlarmService` for fetching alarm data and the `OptionsService`\n * for configuring alarms view options.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class AlarmsViewService {\n  readonly ALARM_REFRESH_TYPE_KEY: keyof ApplicationOptions = 'alarmsRefreshType';\n  readonly DEFAULT_INTERVAL_VALUE = 30_000;\n  readonly DEFAULT_REFRESH_OPTION_VALUE = 'interval';\n  readonly DEFAULT_INTERVAL_VALUES = [5_000, 10_000, 15_000, 30_000, 60_000];\n  readonly REALTIME_UPDATE_ALARMS_MESSAGE = gettext('The list was updated, click to refresh.');\n\n  isIntervalEnabled$: Observable<boolean>;\n  reloadAlarmsList$ = new Subject<void>();\n\n  private _isIntervalEnabled: BehaviorSubject<boolean>;\n\n  constructor(\n    private alarmService: AlarmService,\n    private optionsService: OptionsService\n  ) {\n    if (this.isIntervalRefresh()) {\n      this._isIntervalEnabled = new BehaviorSubject<boolean>(true);\n      this.isIntervalEnabled$ = this._isIntervalEnabled.asObservable();\n    }\n  }\n\n  /**\n   * Emits a subject to initialize the alarms reloading.\n   */\n  updateAlarmList(): void {\n    this.reloadAlarmsList$.next();\n  }\n\n  /**\n   * Retrieves a list of alarms filtered by specified severities and other optional query filters.\n   *\n   * @param severities an array of severities to filter the alarms.\n   * @param showCleared flag indicating whether to show cleared alarms. Defaults to false.\n   * @param selectedDates an array of two dates to filter alarms by creation and last update dates.\n   * @param filter additional query filters for retrieving alarms.\n   *\n   * @returns A promise that resolves to a list of alarms satisfying the specified filters.\n   */\n  retrieveFilteredAlarms(\n    severities: SeverityType[],\n    showCleared = false,\n    selectedDates?: [Date, Date],\n    filter?: AlarmQueryFilter\n  ): Promise<IResultList<IAlarm>> {\n    const severitiesQuery = this.getSeverityQueryParameter(severities);\n    const statusesQuery = this.getStatusQueryParameter(showCleared);\n\n    const _filter: AlarmQueryFilter = {\n      pageSize: 50,\n      withTotalPages: true,\n      ...(severitiesQuery && { severity: severitiesQuery }),\n      ...(statusesQuery && { status: statusesQuery }),\n      ...(selectedDates && {\n        lastUpdatedFrom: selectedDates[0].toISOString(),\n        createdTo: selectedDates[1].toISOString()\n      }),\n      ...filter\n    };\n    return this.alarmService.list(_filter);\n  }\n\n  retrieveAlarmsByDate(dates: DateTimeContext) {\n    return this.alarmService.list({\n      lastUpdatedFrom: dates[0].toISOString(),\n      createdTo: dates[1].toISOString(),\n      pageSize: 50,\n      withTotalPages: true\n    });\n  }\n\n  /**\n   * Updates the state to enable or disable intervals.\n   * @param value - A boolean value to indicate whether to enable intervals.\n   */\n  updateIntervalState(value: boolean): void {\n    this._isIntervalEnabled?.next(value);\n  }\n\n  /**\n   * Fetches the count of alarms filtered by severity and clearance status.\n   *\n   * @param severity - The severity level to filter by (e.g., CRITICAL, MAJOR, etc.).\n   * @param showCleared - Whether or not to include cleared alarms in the count.\n   * @param filter - Additional filter criteria for alarms.\n   *\n   * @returns A promise that resolves to the number of alarms that match the filter criteria.\n   *\n   */\n  async getAlarmsCountBySeverity(\n    severity: SeverityType,\n    showCleared: boolean,\n    filter?: AlarmQueryFilter\n  ): Promise<number> {\n    const statusesQuery = this.getStatusQueryParameter(showCleared);\n    const _filter: AlarmQueryFilter = {\n      ...(severity && { severity: severity }),\n      ...(statusesQuery && { status: statusesQuery }),\n      ...filter\n    };\n    const { data } = await this.alarmService.count(_filter);\n\n    return data;\n  }\n\n  /**\n   * Retrieves the current alarms refresh type from the OptionsService\n   * and determines whether it is set to \"interval\".\n   *\n   * @returns `true` if the alarms refresh type is \"interval,\" otherwise `false`.\n   */\n  isIntervalRefresh(): boolean {\n    const value = this.optionsService.get(this.ALARM_REFRESH_TYPE_KEY, 'interval');\n    return value === 'interval';\n  }\n\n  /**\n   * Updates the list of selected severities based on the new severity filter.\n   *\n   * @param severityUpdates - The object representing the updates to each severity.\n   *\n   * @returns An array representing the updated selected severities.\n   */\n  updateSelectedSeverities(severityUpdates: SeverityFilter): SeverityType[] {\n    return (Object.keys(severityUpdates) as SeverityType[])\n      .filter(key => severityUpdates[key])\n      .map(key => key.toUpperCase() as SeverityType);\n  }\n\n  /**\n   * Clears all active alarms of the selected severities.\n   *\n   * This method clears all active alarms for the given list of severities by making bulk update calls. If no severities are selected, it defaults to using all available severities.\n   * It works by sending a series of update requests for each severity and returns a Promise that resolves with an object indicating if all alarms were resolved immediately.\n   *\n   * @param selectedSeverities An array of severities to be cleared. If not provided, all severities will be cleared.\n   * @param sourceId - Identifier for the source associated with the alarms to be cleared.\n   *\n   * @returns A Promise that resolves with an object with a flag `resolvedImmediately`. The flag is true if all alarms for all selected severities were cleared successfully; otherwise false.\n   *\n   * **Example**\n   * ```typescript\n   * const severitiesToClear: SeverityType[] = [Severity.MAJOR, Severity.MINOR];\n   *\n   * clearAllActiveAlarms(severitiesToClear).then(({ resolvedImmediately }) => {\n   *   if (resolvedImmediately) {\n   *     console.log('All selected alarms were cleared successfully.');\n   *   } else {\n   *     console.log('Some alarms could not be cleared.');\n   *   }\n   * });\n   * ```\n   *\n   * **Note**\n   * - The method uses the `alarmService.updateBulk` for each severity to clear the active alarms.\n   * - It may fetch the `sourceId` based on the view (if applicable) and include it as a query parameter in the update calls.\n   * - The method returns immediately but the returned Promise needs to have a `then` or `catch` method call to handle the result or error respectively.\n   * - Uses `Promise.all` to wait for all update requests to complete before resolving the final result.\n   */\n  async clearAllActiveAlarms(\n    selectedSeverities: SeverityType[],\n    sourceId: string | number\n  ): Promise<{ resolvedImmediately: boolean }> {\n    const severitiesToUpdate = selectedSeverities || Severity;\n\n    const promises = Object.values(severitiesToUpdate).map((severity: SeverityType) => {\n      const commonParams = { resolved: false, severity };\n\n      const parameters = sourceId\n        ? {\n            ...commonParams,\n            source: sourceId,\n            withSourceAssets: true,\n            withSourceDevices: true\n          }\n        : commonParams;\n\n      return this.alarmService.updateBulk({ status: AlarmStatus.CLEARED }, parameters);\n    });\n\n    const responses = await Promise.all(promises);\n    return {\n      resolvedImmediately: responses.every(res => res)\n    };\n  }\n\n  /**\n   * Returns the correct link based on the provided context data.\n   * @param contextData The context the navigation was triggered from.\n   * @param alarm The alarm to navigate to.\n   * @returns A link to be used as an url navigation.\n   */\n  getRouterLink(contextData?: ContextData, alarm?: IAlarm): string {\n    let detailUrl = `/${ALARMS_PATH}`;\n    if (alarm) {\n      detailUrl = `/${ALARMS_PATH}/${alarm.id}`;\n    }\n    if (!contextData) {\n      return detailUrl;\n    }\n\n    switch (contextData.context) {\n      case ViewContext.Device:\n        return `/device/${contextData.contextData.id}${detailUrl}`;\n      case ViewContext.Group:\n        return `/group/${contextData.contextData.id}${detailUrl}`;\n      case ViewContext.Simulators:\n        return `/simulators/${contextData.contextData.id}${detailUrl}`;\n      default:\n        return detailUrl;\n    }\n  }\n\n  /**\n   * Returns the correct array navigation.\n   * @param contextData The context the navigation was triggered from.\n   * @param alarm The alarm to navigate to.\n   * @returns A link to be used as a router.navigation.\n   */\n  getRouterNavigationArray(contextData?: ContextData, alarm?: IAlarm): string[] {\n    return this.getRouterLink(contextData, alarm).split('/').filter(Boolean);\n  }\n\n  /**\n   * Returns the correct from and to dates based on the selected interval\n   * @param intervalId the selected interval. E.g. 'none', 'hours', 'custom' ...\n   * @returns The calculated date context based on the selected interval.\n   */\n  getDateTimeContextByInterval(intervalId: AlarmFilterInterval['id']): DateTimeContext {\n    const interval = INTERVALS_EXTENDED.find(({ id }) => id === intervalId);\n    if (interval.id === 'none') {\n      return [new Date(0), new Date()];\n    }\n\n    const dateTo = new Date();\n    const dateFrom = new Date(dateTo.valueOf() - interval.timespanInMs);\n    return [dateFrom, dateTo];\n  }\n\n  /**\n   * Creates a value for query parameter for filtering alarms by severity based on array of selected severities.\n   *\n   * @param severities - An array of alarm severity types to include in the filter.\n   * If the array is empty or undefined, no severity filter will be applied.\n   *\n   * @returns A comma-separated string of selected alarm severities,\n   * or null if no severities are provided.\n   */\n  private getSeverityQueryParameter(severities: SeverityType[]): string | null {\n    if (!severities || severities.length === 0) {\n      return;\n    }\n    if (severities.length === Object.keys(Severity).length) {\n      return;\n    }\n\n    return severities.join(',');\n  }\n\n  /**\n   * Creates a value for query parameter for filtering alarms by statuses based on showCleared option.\n   *\n   * @param showCleared - A flag indicating whether to include cleared statuses.\n   * If true, all statuses, including 'CLEARED', will be included; if false, 'CLEARED' will be excluded.\n   *\n   * @returns A comma-separated string of alarm statuses.\n   */\n  private getStatusQueryParameter(showCleared: boolean): string {\n    const statuses = Object.keys(ALARM_STATUS_LABELS) as AlarmStatusType[];\n    const filteredStatuses = showCleared\n      ? statuses\n      : statuses.filter(status => status !== 'CLEARED');\n    return filteredStatuses.join(',');\n  }\n}\n"]}
@@ -28,4 +28,4 @@ export var BuiltInActionType;
28
28
  /** Export built-in action. */
29
29
  BuiltInActionType["Export"] = "EXPORT";
30
30
  })(BuiltInActionType || (BuiltInActionType = {}));
31
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.model.js","sourceRoot":"","sources":["../../../../core/data-grid/data-grid.model.ts"],"names":[],"mappings":"AA0KA,MAAM,CAAC,MAAM,sBAAsB,GAAG,EAAE,CAAC;AAEzC,4CAA4C;AAC5C,MAAM,CAAC,MAAM,mBAAmB,GAAG;IACjC,6CAA6C;IAC7C,IAAI,EAAE,CAAC;IAEP,gDAAgD;IAChD,OAAO,EAAE,CAAC;IAEV,mDAAmD;IACnD,YAAY,EAAE,IAAI;IAElB,kDAAkD;IAClD,WAAW,EAAE,IAAI;CAClB,CAAC;AAaF,yBAAyB;AACzB,MAAM,CAAN,IAAY,mBAMX;AAND,WAAY,mBAAmB;IAC7B,6DAA6D;IAC7D,mDAA4B,CAAA;IAE5B,6DAA6D;IAC7D,mDAA4B,CAAA;AAC9B,CAAC,EANW,mBAAmB,KAAnB,mBAAmB,QAM9B;AA6ND,mCAAmC;AACnC,MAAM,CAAN,IAAY,iBASX;AATD,WAAY,iBAAiB;IAC3B,4BAA4B;IAC5B,kCAAa,CAAA;IAEb,8BAA8B;IAC9B,sCAAiB,CAAA;IAEjB,8BAA8B;IAC9B,sCAAiB,CAAA;AACnB,CAAC,EATW,iBAAiB,KAAjB,iBAAiB,QAS5B","sourcesContent":["import { TemplateRef, Type } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { ActivatedRoute } from '@angular/router';\nimport { IResultList } from '@c8y/client';\nimport { FormlyFieldConfig } from '@ngx-formly/core';\nimport { Observable } from 'rxjs';\nimport { ExtensionFactory } from '../common/extension-hooks';\nimport { GridConfigContext } from './data-grid-configuration.model';\n\n/** Describes the interface of the data grid. */\nexport interface DataGrid {\n  /** The list of columns. */\n  columns: Column[];\n\n  /** The list of items. */\n  rows: Row[];\n\n  /** Pagination object. */\n  pagination: Pagination;\n\n  /** A callback function to fetch server data. */\n  serverSideDataCallback: ServerSideDataCallback;\n\n  /** Whether items are selectable. */\n  selectable: boolean;\n\n  /** The name of the primary key property. */\n  selectionPrimaryKey: string;\n\n  /** Data grid display options. */\n  displayOptions: DisplayOptions;\n\n  /** Individual action controls. */\n  actionControls: ActionControl[];\n\n  /** Bulk action controls. */\n  bulkActionControls: BulkActionControl[];\n\n  /** Header action controls. */\n  headerActionControls?: HeaderActionControl[];\n}\n\n/** Describes a data grid column. */\nexport interface Column {\n  /** The name for the column. */\n  name: string | SpecialColumnName;\n  /** The column's header (if not given, `name` is used by default). */\n  header?: string;\n  /** The path in a row item to read the cell value from. */\n  path?: string;\n  /** Whether the column is displayed. */\n  visible?: boolean;\n  /** Whether the column can be moved to another position. */\n  positionFixed?: boolean;\n  /** Marks a user configured custom column */\n  custom?: boolean;\n  /** Whether the column can be resized. */\n  resizable?: boolean;\n  /** Optional type of data in the column (used to set data-type attribute, e.g. for additional styling). */\n  dataType?: ColumnDataType;\n  /** The column's size, e.g. \"40 px\". */\n  gridTrackSize?: string;\n  /** Additional CSS classes for the header cell. */\n  headerCSSClassName?: string | string[];\n  /** Additional CSS classes for data cells. */\n  cellCSSClassName?: string | string[];\n\n  /** Whether the column is sortable. */\n  sortable?: boolean;\n  /** Whether the sort order is ascending, descending or not specified. */\n  sortOrder?: SortOrder;\n  sortingConfig?: ColumnSortingConfig;\n\n  /** Whether the column is filterable. */\n  filterable?: boolean;\n  /** The string to search for or a function for client-side filtering. */\n  filterPredicate?: string | FilterPredicateFunction;\n  /** Custom filtering form renderer can set any value here and it can be used to build a query to the server. */\n  externalFilterQuery?: any;\n  filteringConfig?: FormlyColumnFilteringConfig;\n\n  /** Custom data cell renderer component. Inject `CellRendererContext` to get access to data value, item and column object. */\n  cellRendererComponent?: Type<any>;\n  /** Custom header cell renderer component. Inject `CellRendererContext` to get access to header value and column object. */\n  headerCellRendererComponent?: Type<any>;\n  /** Custom filtering form renderer component. Inject `FilteringFormRendererContext` to get access to column object and methods: applyFilter, resetFilter. */\n  filteringFormRendererComponent?: Type<any>;\n}\n\n/** Describes a column configuration. */\nexport interface ColumnConfig {\n  /** The name for the column. */\n  name?: string;\n\n  /** Whether the column is displayed. */\n  visible?: boolean;\n\n  /** Whether the sort order is ascending, descending or not specified. */\n  sortOrder?: SortOrder;\n\n  /** The settings of filter in a column. */\n  filter?: Filter;\n}\n\n/** Describes a custom column configuration. */\nexport interface CustomColumnConfig extends ColumnConfig {\n  /** JSON path to the managed object property to be displayed */\n  path: string;\n\n  /** Column header title */\n  header: string;\n\n  /** Flag to identify custom columns */\n  custom: boolean;\n}\n\n/** Describes the settings of filter in a column. */\nexport interface Filter {\n  /** Custom filtering form renderer can set any value here and it can be used to build a query to the server. */\n  externalFilterQuery?: any;\n}\n\n/** Describes an object with data grid configuration. */\nexport interface GridConfig {\n  /** The configuration objects for all the columns. */\n  columns: ColumnConfig[];\n\n  /** Pagination object. */\n  pagination: Pagination;\n}\n\n/**  */\nexport const enum SpecialColumnName {\n  /** Column with checkbox. */\n  Checkbox = 'checkbox',\n\n  /** Column with radio button. */\n  RadioButton = 'radio-button',\n\n  /** Column with row actions. */\n  Actions = 'actions'\n}\n\n/**  */\nexport const enum ColumnDataType {\n  /** Column with icon. */\n  Icon = 'icon',\n\n  /** Numeric column. */\n  Numeric = 'numeric',\n\n  /** Column with short text. */\n  TextShort = 'text-short',\n\n  /** Column with long text. */\n  TextLong = 'text-long'\n}\n\n/** Classes for column data record. */\nexport const enum ColumnDataRecordClassName {\n  /** An icon. */\n  Icon = 'data-record-icon',\n\n  /** A header. */\n  Header = 'data-record-header',\n\n  /** Default - empty. */\n  Default = ''\n}\n\nexport const minColumnGridTrackSize = 80;\n\n/** Maps column types to relative widths. */\nexport const ratiosByColumnTypes = {\n  /** The width ration for icon column type. */\n  icon: 1,\n\n  /** The width ration for numeric column type. */\n  numeric: 1,\n\n  /** The width ration for short text column type. */\n  'text-short': 1.67,\n\n  /** The width ration for long text column type. */\n  'text-long': 3.33\n};\n\n/** Sorting order: ascending, descending, or not specified. */\nexport type SortOrder = 'asc' | 'desc' | '';\n\n/**\n * A filter predicate function.\n * @param item The current item to be checked.\n * @param path The property path configured in the current column.\n * @returns The boolean value indicating whether the item matches a condition or not.\n */\nexport type FilterPredicateFunction = (item: object, path: string) => boolean;\n\n/** Filtering actions. */\nexport enum FilteringActionType {\n  /** Action invoked when filter settings are to be applied. */\n  ApplyFilter = 'APPLY_FILTER',\n\n  /** Action invoked when filter settings are to be cleared. */\n  ResetFilter = 'RESET_FILTER'\n}\n\nexport interface FormlyColumnFilteringConfig {\n  /** Defines a FieldConfig configuration for Formly.  */\n  fields?: FormlyFieldConfig[];\n  /** Defines a JSON schema for filtering config model. Can be used instead of `fields` */\n  schema?: object;\n  /** Defines a model that will be applied to rendered form. */\n  model?: object;\n  /** Defines FormGroup instance */\n  formGroup?: FormGroup;\n  /**\n   * Transforms a filtering config model to an array of partial filter chip objects.\n   * @param model An object with defined structure (e.g. by schema).\n   * @returns An array of partial filter chip objects, each containing at least `displayValue` and the actual `value` to be updated.\n   * Optionally, other properties from `FilterChip` are allowed, for example, a custom `remove` callback to be executed when a chip is being removed.\n   */\n  generateChips?: (model: any) => PartialFilterChipGenerationType[];\n  /**\n   * Transforms a filtering config model (e.g. coming from schema form component) to a query object.\n   * However, using schema form component is not necessary.\n   * Model can be defined arbitrarily but must converted to a valid query object.\n   * @param model An object with defined structure (e.g. by schema).\n   * @returns A query object to be used to generate a query string (QueryUtils).\n   */\n  getFilter: (model: any) => any;\n}\n\nexport interface ColumnSortingConfig {\n  pathSortingConfigs: PathSortingConfig[];\n}\n\nexport interface PathSortingConfig {\n  path: string;\n  sortOrderModifier?: SortOrderModifier;\n}\n\nexport const enum SortOrderModifier {\n  Keep,\n  Invert\n}\n\n/** Describes an item in the row. */\nexport interface Row {\n  /** The unique identifier of the item. */\n  id: string;\n\n  /** Any item property. */\n  [key: string]: any;\n}\n\n/** Describes a pagination object. */\nexport interface Pagination {\n  /** The number of the current page. */\n  currentPage?: number;\n\n  /** The number of the next page. */\n  nextPage?: number;\n\n  /** The number of items on a single page. */\n  pageSize: number;\n}\n\n/**\n * A callback function to fetch server data.\n * @param dataSourceModifier The current data source modifier.\n * @returns Returns the result from server.\n */\nexport type ServerSideDataCallback = (\n  dataSourceModifier: DataSourceModifier\n) => ServerSideDataResult | Promise<ServerSideDataResult> | Observable<ServerSideDataResult>;\n\n/** Describes a data source modifier for requesting server data. */\nexport interface DataSourceModifier {\n  /** The list of columns. */\n  columns: Column[];\n\n  /** Text to search. */\n  searchText: string;\n\n  /** Pagination object. */\n  pagination: Pagination;\n\n  /** Selection info object. */\n  selection: {\n    /** Whether the selection is enabled. */\n    enabled: boolean;\n\n    /** The name of the primary key. */\n    primaryKey: string;\n  };\n}\n\n/** Describes a result from server with data and additional statistics. */\nexport type ServerSideDataResult = IResultList<object> & {\n  /** The real grand total number of items (the whole dataset). */\n  size: number;\n\n  /** The number of items after filtering applied to the whole dataset (subset). */\n  filteredSize: number;\n\n  /** The list of ids of all filtered items (subset). */\n  filteredDataIds?: string[];\n};\n\n/** Describes an object with data source statistics. */\nexport interface DataSourceStats {\n  /** The real grand total number of items (the whole dataset). */\n  size: number;\n\n  /** The number of items after filtering applied to the whole dataset (subset). */\n  filteredSize: number;\n\n  /** The number of the current page. */\n  currentPage: number;\n\n  /** The number of the next page. */\n  nextPage?: number;\n\n  /** The number of items currently shown in the list view, a.k.a. current page (what the user sees on screen). */\n  currentPageSize: number;\n\n  /** The number of items on the first page.  */\n  firstPageSize: number;\n}\n\n/** Describes data grid display options. */\nexport interface DisplayOptions {\n  /** Show or hide zebra-striping in the table */\n  striped: boolean;\n\n  /** Show or hide each cell border */\n  bordered: boolean;\n\n  /** Show or hide the grid header */\n  gridHeader: boolean;\n\n  /** Show or hide filter label in the grid header */\n  filter: boolean;\n\n  /** Enable to display a background color on hover */\n  hover: boolean;\n}\n\n/** Describes a data grid action control for individual item. */\nexport interface ActionControl {\n  /** The type of the action, predefined or custom. */\n  type: BuiltInActionType | string;\n\n  /** The label for the action button. */\n  text?: string;\n\n  /** The icon for the action button. */\n  icon?: string;\n\n  /** The icon classes for the action button icon. */\n  iconClasses?: string;\n\n  /** Action icon will be visible on hover only */\n  showOnHover?: boolean;\n\n  /**\n   * A callback function.\n   * @param item The item to perform the action on.\n   * @param reload The function to call, if you want to reload the grid.\n   */\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  callback: ((item: Row, reload: () => void) => void) | Function;\n\n  /**\n   * Determines if the action should be shown for given item (if not defined, the action will be shown always).\n   * @param item The item for which the action is supposed to be performed.\n   */\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  showIf?: ((item: Row & string[]) => boolean | Promise<boolean> | Observable<boolean>) | Function;\n\n  /**\n   * Defines the order in which action controls appear. Higher value means earlier position.\n   * Controls without priority are handled with priority = 0. If you want to place an action after\n   * an action without priority, negative numbers can be used.\n   */\n  priority?: number;\n\n  [key: string]: any;\n}\n\n/** Describes a data grid action control for multiple items. */\nexport interface BulkActionControl extends ActionControl {\n  /**\n   * A callback function.\n   * @param selectedItemIds The list of ids of the selected items.\n   * @param reload The function to call, if you want to reload the grid.\n   */\n  callback(selectedItemIds: string[], reload: () => void): void;\n\n  /**\n   * Determines if the action should be shown for given selected items (if not defined, the action will be shown always).\n   * @param selectedItemIds The list of ids of the selected items for which the action is supposed to be performed.\n   */\n  showIf?(selectedItemIds: string[]): boolean;\n}\n\n/** Describes a data grid action control for the header. */\nexport interface HeaderActionControl extends ActionControl {\n  /**\n   * Custom template can be provided. If no template is provided,\n   * the default headerActionControl template is used.\n   */\n  template?: TemplateRef<any>;\n\n  /**\n   * A callback function.\n   */\n  callback(): void;\n\n  /**\n   * Determines if the action should be shown.\n   */\n  showIf?(): boolean;\n}\n\n/** Predefined types of actions. */\nexport enum BuiltInActionType {\n  /** Edit built-in action. */\n  Edit = 'EDIT',\n\n  /** Delete built-in action. */\n  Delete = 'DELETE',\n\n  /** Export built-in action. */\n  Export = 'EXPORT'\n}\n\n/**\n * Allows to attach action controls to specified grids.\n */\nexport interface ActionControlHook {\n  /**\n   * The action control(s) that will be attached to the grid.\n   */\n  actionControls: ActionControl | ActionControl[];\n  /**\n   * A functions that determines to which grid(s) the action control(s) will be attached.\n   * Not providing a function results in the actions control(s) not being attached to any grid.\n   */\n  matchesGrid: (\n    route: ActivatedRoute,\n    context?: GridConfigContext\n  ) => boolean | Promise<boolean> | Observable<boolean>;\n}\n\n/**\n * Factory to implement in order to add action controls from an extension.\n */\nexport type ActionControlFactory = ExtensionFactory<ActionControlHook>;\n\n/**\n * Defines an interface for a filter chip object, which represents a filter applied to a column.\n */\nexport interface FilterChip {\n  /**\n   * The actual value that the chip will hold.\n   * It can be just a string or a more complex object like\n   * {id: 123, name: Test, value: test}.\n   */\n  value: any;\n\n  /**\n   * The value that the chip will display in the dropdown.\n   */\n  displayValue: string;\n\n  /**\n   * Optional label that will be displayed if filter chips are separated into multiple groups.\n   */\n  label?: string;\n\n  /** An optional property that holds the path to the chip value in the externalFilterQuery. */\n  path?: string[];\n\n  /**\n   * An optional property that holds the form value taken from the column configuration.\n   */\n  externalFilterQuery?: any;\n\n  /**\n   * An optional property that holds the formly filtering configuration for the column that this filter is applied to.\n   */\n  filteringConfig?: FormlyColumnFilteringConfig;\n\n  /** An optional property that holds a string to search for. */\n  filterPredicate?: string;\n\n  /**\n   * The name of the column that this filter is applied to.\n   */\n  columnName: string | SpecialColumnName;\n\n  /**\n   * An optional function to remove this filter from the column.\n   * If not provided will set default removal function that will reduce the external query by removing the object that is resolved by the path set in the FilterChip.\n   * @returns An object defined by the `FilterChip` type, including the `columnName` and  updated `externalFilterQuery` or 'filterPredicate' properties.\n   * The returned object may also include additional properties defined by the `FilterChip` type as partials.\n   */\n  remove?: () => PartialFilterChipRemovalType;\n}\n\n/**\n * Represents a partial filter chip with either 'columnName' and 'externalFilterQuery' or 'columnName' and 'filterPredicate'.\n * @typedef {Object} PartialFilterChipRemovalType\n * @property {string} columnName - The column name for the filter chip.\n * @property {any} [externalFilterQuery] - The external filter query for the chip used for complex filters.\n * @property {any} [filterPredicate] - The filtering predicate for the chip used for simple filters with client-side filtering.\n * @property {...FilterChip} [optionalProperties] - Optional properties from the FilterChip type.\n */\nexport type PartialFilterChipRemovalType = (\n  | Required<Pick<FilterChip, 'columnName' | 'externalFilterQuery'>>\n  | Required<Pick<FilterChip, 'columnName' | 'filterPredicate'>>\n) &\n  Partial<FilterChip>;\n\n/**\n * Represents a partial filter chip with required properties 'displayValue' and 'value'.\n * @typedef {Object} PartialFilterChipGenerationType\n * @property {string} displayValue - The display value for the filter chip.\n * @property {any} value - The value for the filter chip.\n * @property {...FilterChip} [optionalProperties] - Optional properties from the FilterChip type.\n */\nexport type PartialFilterChipGenerationType = Required<Pick<FilterChip, 'displayValue' | 'value'>> &\n  Partial<FilterChip>;\n\n/**\n * Defines an interface for a mapper function that maps a `FormlyFieldConfig` to a `FilterChip`.\n */\nexport interface FilterMapper {\n  /**\n   * The type or types of the `FormlyFieldConfig` that this mapper applies to.\n   */\n  fieldType: string[] | string;\n\n  /**\n   * Maps a `FormlyFieldConfig` and a `FilterChip` to an `Observable` of a `FilterChip`.\n   *\n   * This function extends the provided `FilterChip` object with additional properties based on the information in the `FormlyFieldConfig`.\n   * The mapping process depends on the specific implementation of the `FilterMapper`.\n   *\n   * @param field - The `FormlyFieldConfig` to map.\n   * @param filter - The `FilterChip` to map.\n   * @returns An `Observable` that emits the mapped `FilterChip`.\n   * If undefined is returned an error is thrown and the chip is not visualized.\n   *\n   * ```typescript\n   * // Example implementation of `map` function in a `FilterMapper`\n   * map(field: FormlyFieldConfig, filter: FilterChip): Observable<FilterChip> {\n   *   if (this.fieldType.includes(field.type.toString())) {\n   *     return toObservable(field.templateOptions.options).pipe(\n   *       map(options => {\n   *         const object = options.find(option => option.value === get(filter.externalFilterQuery, filter.path));\n   *         return {\n   *           ...filter,\n   *           value: object,\n   *           displayValue: object?.label\n   *         };\n   *       })\n   *     );\n   *   }\n   * }\n   * ```\n   */\n  map: (field: FormlyFieldConfig, filter: FilterChip) => Observable<FilterChip>;\n}\n"]}
31
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.model.js","sourceRoot":"","sources":["../../../../core/data-grid/data-grid.model.ts"],"names":[],"mappings":"AA4KA,MAAM,CAAC,MAAM,sBAAsB,GAAG,EAAE,CAAC;AAEzC,4CAA4C;AAC5C,MAAM,CAAC,MAAM,mBAAmB,GAAG;IACjC,6CAA6C;IAC7C,IAAI,EAAE,CAAC;IAEP,gDAAgD;IAChD,OAAO,EAAE,CAAC;IAEV,mDAAmD;IACnD,YAAY,EAAE,IAAI;IAElB,kDAAkD;IAClD,WAAW,EAAE,IAAI;CAClB,CAAC;AAaF,yBAAyB;AACzB,MAAM,CAAN,IAAY,mBAMX;AAND,WAAY,mBAAmB;IAC7B,6DAA6D;IAC7D,mDAA4B,CAAA;IAE5B,6DAA6D;IAC7D,mDAA4B,CAAA;AAC9B,CAAC,EANW,mBAAmB,KAAnB,mBAAmB,QAM9B;AA6ND,mCAAmC;AACnC,MAAM,CAAN,IAAY,iBASX;AATD,WAAY,iBAAiB;IAC3B,4BAA4B;IAC5B,kCAAa,CAAA;IAEb,8BAA8B;IAC9B,sCAAiB,CAAA;IAEjB,8BAA8B;IAC9B,sCAAiB,CAAA;AACnB,CAAC,EATW,iBAAiB,KAAjB,iBAAiB,QAS5B","sourcesContent":["import { TemplateRef, Type } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { ActivatedRoute } from '@angular/router';\nimport { IResultList } from '@c8y/client';\nimport { FormlyFieldConfig } from '@ngx-formly/core';\nimport { Observable } from 'rxjs';\nimport { ExtensionFactory } from '../common/extension-hooks';\nimport { GridConfigContext } from './data-grid-configuration.model';\n\n/** Describes the interface of the data grid. */\nexport interface DataGrid {\n  /** The list of columns. */\n  columns: Column[];\n\n  /** The list of items. */\n  rows: Row[];\n\n  /** Pagination object. */\n  pagination: Pagination;\n\n  /** A callback function to fetch server data. */\n  serverSideDataCallback: ServerSideDataCallback;\n\n  /** Whether items are selectable. */\n  selectable: boolean;\n\n  /** The name of the primary key property. */\n  selectionPrimaryKey: string;\n\n  /** Data grid display options. */\n  displayOptions: DisplayOptions;\n\n  /** Individual action controls. */\n  actionControls: ActionControl[];\n\n  /** Bulk action controls. */\n  bulkActionControls: BulkActionControl[];\n\n  /** Header action controls. */\n  headerActionControls?: HeaderActionControl[];\n}\n\n/** Describes a data grid column. */\nexport interface Column {\n  /** The name for the column. */\n  name: string | SpecialColumnName;\n  /** The column's header (if not given, `name` is used by default). */\n  header?: string;\n  /** The path in a row item to read the cell value from. */\n  path?: string;\n  /** Whether the column is displayed. */\n  visible?: boolean;\n  /** Whether the column can be moved to another position. */\n  positionFixed?: boolean;\n  /** Marks a user configured custom column */\n  custom?: boolean;\n  /** Whether the column can be resized. */\n  resizable?: boolean;\n  /** Optional type of data in the column (used to set data-type attribute, e.g. for additional styling). */\n  dataType?: ColumnDataType;\n  /** The column's size, e.g. \"40 px\". */\n  gridTrackSize?: string;\n  /** Additional CSS classes for the header cell. */\n  headerCSSClassName?: string | string[];\n  /** Additional CSS classes for data cells. */\n  cellCSSClassName?: string | string[];\n\n  /** Whether the column is sortable. */\n  sortable?: boolean;\n  /** Whether the sort order is ascending, descending or not specified. */\n  sortOrder?: SortOrder;\n  sortingConfig?: ColumnSortingConfig;\n\n  /** Whether the column is filterable. */\n  filterable?: boolean;\n  /** The string to search for or a function for client-side filtering. */\n  filterPredicate?: string | FilterPredicateFunction;\n  /** Custom filtering form renderer can set any value here and it can be used to build a query to the server. */\n  externalFilterQuery?: any;\n  filteringConfig?: FormlyColumnFilteringConfig;\n\n  /** Custom data cell renderer component. Inject `CellRendererContext` to get access to data value, item and column object. */\n  cellRendererComponent?: Type<any>;\n  /** Custom header cell renderer component. Inject `CellRendererContext` to get access to header value and column object. */\n  headerCellRendererComponent?: Type<any>;\n  /** Custom filtering form renderer component. Inject `FilteringFormRendererContext` to get access to column object and methods: applyFilter, resetFilter. */\n  filteringFormRendererComponent?: Type<any>;\n}\n\n/** Describes a column configuration. */\nexport interface ColumnConfig {\n  /** The name for the column. */\n  name?: string;\n\n  /** Whether the column is displayed. */\n  visible?: boolean;\n\n  /** Whether the sort order is ascending, descending or not specified. */\n  sortOrder?: SortOrder;\n\n  /** The settings of filter in a column. */\n  filter?: Filter;\n}\n\n/** Describes a custom column configuration. */\nexport interface CustomColumnConfig extends ColumnConfig {\n  /** JSON path to the managed object property to be displayed */\n  path: string;\n\n  /** Column header title */\n  header: string;\n\n  /** Flag to identify custom columns */\n  custom: boolean;\n}\n\n/** Describes the settings of filter in a column. */\nexport interface Filter {\n  /** Custom filtering form renderer can set any value here and it can be used to build a query to the server. */\n  externalFilterQuery?: any;\n  /** An optional property that holds a string to search for. */\n  filterPredicate?: string | FilterPredicateFunction;\n}\n\n/** Describes an object with data grid configuration. */\nexport interface GridConfig {\n  /** The configuration objects for all the columns. */\n  columns: ColumnConfig[];\n\n  /** Pagination object. */\n  pagination: Pagination;\n}\n\n/**  */\nexport const enum SpecialColumnName {\n  /** Column with checkbox. */\n  Checkbox = 'checkbox',\n\n  /** Column with radio button. */\n  RadioButton = 'radio-button',\n\n  /** Column with row actions. */\n  Actions = 'actions'\n}\n\n/**  */\nexport const enum ColumnDataType {\n  /** Column with icon. */\n  Icon = 'icon',\n\n  /** Numeric column. */\n  Numeric = 'numeric',\n\n  /** Column with short text. */\n  TextShort = 'text-short',\n\n  /** Column with long text. */\n  TextLong = 'text-long'\n}\n\n/** Classes for column data record. */\nexport const enum ColumnDataRecordClassName {\n  /** An icon. */\n  Icon = 'data-record-icon',\n\n  /** A header. */\n  Header = 'data-record-header',\n\n  /** Default - empty. */\n  Default = ''\n}\n\nexport const minColumnGridTrackSize = 80;\n\n/** Maps column types to relative widths. */\nexport const ratiosByColumnTypes = {\n  /** The width ration for icon column type. */\n  icon: 1,\n\n  /** The width ration for numeric column type. */\n  numeric: 1,\n\n  /** The width ration for short text column type. */\n  'text-short': 1.67,\n\n  /** The width ration for long text column type. */\n  'text-long': 3.33\n};\n\n/** Sorting order: ascending, descending, or not specified. */\nexport type SortOrder = 'asc' | 'desc' | '';\n\n/**\n * A filter predicate function.\n * @param item The current item to be checked.\n * @param path The property path configured in the current column.\n * @returns The boolean value indicating whether the item matches a condition or not.\n */\nexport type FilterPredicateFunction = (item: object, path: string) => boolean;\n\n/** Filtering actions. */\nexport enum FilteringActionType {\n  /** Action invoked when filter settings are to be applied. */\n  ApplyFilter = 'APPLY_FILTER',\n\n  /** Action invoked when filter settings are to be cleared. */\n  ResetFilter = 'RESET_FILTER'\n}\n\nexport interface FormlyColumnFilteringConfig {\n  /** Defines a FieldConfig configuration for Formly.  */\n  fields?: FormlyFieldConfig[];\n  /** Defines a JSON schema for filtering config model. Can be used instead of `fields` */\n  schema?: object;\n  /** Defines a model that will be applied to rendered form. */\n  model?: object;\n  /** Defines FormGroup instance */\n  formGroup?: FormGroup;\n  /**\n   * Transforms a filtering config model to an array of partial filter chip objects.\n   * @param model An object with defined structure (e.g. by schema).\n   * @returns An array of partial filter chip objects, each containing at least `displayValue` and the actual `value` to be updated.\n   * Optionally, other properties from `FilterChip` are allowed, for example, a custom `remove` callback to be executed when a chip is being removed.\n   */\n  generateChips?: (model: any) => PartialFilterChipGenerationType[];\n  /**\n   * Transforms a filtering config model (e.g. coming from schema form component) to a query object.\n   * However, using schema form component is not necessary.\n   * Model can be defined arbitrarily but must converted to a valid query object.\n   * @param model An object with defined structure (e.g. by schema).\n   * @returns A query object to be used to generate a query string (QueryUtils).\n   */\n  getFilter: (model: any) => any;\n}\n\nexport interface ColumnSortingConfig {\n  pathSortingConfigs: PathSortingConfig[];\n}\n\nexport interface PathSortingConfig {\n  path: string;\n  sortOrderModifier?: SortOrderModifier;\n}\n\nexport const enum SortOrderModifier {\n  Keep,\n  Invert\n}\n\n/** Describes an item in the row. */\nexport interface Row {\n  /** The unique identifier of the item. */\n  id: string;\n\n  /** Any item property. */\n  [key: string]: any;\n}\n\n/** Describes a pagination object. */\nexport interface Pagination {\n  /** The number of the current page. */\n  currentPage?: number;\n\n  /** The number of the next page. */\n  nextPage?: number;\n\n  /** The number of items on a single page. */\n  pageSize: number;\n}\n\n/**\n * A callback function to fetch server data.\n * @param dataSourceModifier The current data source modifier.\n * @returns Returns the result from server.\n */\nexport type ServerSideDataCallback = (\n  dataSourceModifier: DataSourceModifier\n) => ServerSideDataResult | Promise<ServerSideDataResult> | Observable<ServerSideDataResult>;\n\n/** Describes a data source modifier for requesting server data. */\nexport interface DataSourceModifier {\n  /** The list of columns. */\n  columns: Column[];\n\n  /** Text to search. */\n  searchText: string;\n\n  /** Pagination object. */\n  pagination: Pagination;\n\n  /** Selection info object. */\n  selection: {\n    /** Whether the selection is enabled. */\n    enabled: boolean;\n\n    /** The name of the primary key. */\n    primaryKey: string;\n  };\n}\n\n/** Describes a result from server with data and additional statistics. */\nexport type ServerSideDataResult = IResultList<object> & {\n  /** The real grand total number of items (the whole dataset). */\n  size: number;\n\n  /** The number of items after filtering applied to the whole dataset (subset). */\n  filteredSize: number;\n\n  /** The list of ids of all filtered items (subset). */\n  filteredDataIds?: string[];\n};\n\n/** Describes an object with data source statistics. */\nexport interface DataSourceStats {\n  /** The real grand total number of items (the whole dataset). */\n  size: number;\n\n  /** The number of items after filtering applied to the whole dataset (subset). */\n  filteredSize: number;\n\n  /** The number of the current page. */\n  currentPage: number;\n\n  /** The number of the next page. */\n  nextPage?: number;\n\n  /** The number of items currently shown in the list view, a.k.a. current page (what the user sees on screen). */\n  currentPageSize: number;\n\n  /** The number of items on the first page.  */\n  firstPageSize: number;\n}\n\n/** Describes data grid display options. */\nexport interface DisplayOptions {\n  /** Show or hide zebra-striping in the table */\n  striped: boolean;\n\n  /** Show or hide each cell border */\n  bordered: boolean;\n\n  /** Show or hide the grid header */\n  gridHeader: boolean;\n\n  /** Show or hide filter label in the grid header */\n  filter: boolean;\n\n  /** Enable to display a background color on hover */\n  hover: boolean;\n}\n\n/** Describes a data grid action control for individual item. */\nexport interface ActionControl {\n  /** The type of the action, predefined or custom. */\n  type: BuiltInActionType | string;\n\n  /** The label for the action button. */\n  text?: string;\n\n  /** The icon for the action button. */\n  icon?: string;\n\n  /** The icon classes for the action button icon. */\n  iconClasses?: string;\n\n  /** Action icon will be visible on hover only */\n  showOnHover?: boolean;\n\n  /**\n   * A callback function.\n   * @param item The item to perform the action on.\n   * @param reload The function to call, if you want to reload the grid.\n   */\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  callback: ((item: Row, reload: () => void) => void) | Function;\n\n  /**\n   * Determines if the action should be shown for given item (if not defined, the action will be shown always).\n   * @param item The item for which the action is supposed to be performed.\n   */\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  showIf?: ((item: Row & string[]) => boolean | Promise<boolean> | Observable<boolean>) | Function;\n\n  /**\n   * Defines the order in which action controls appear. Higher value means earlier position.\n   * Controls without priority are handled with priority = 0. If you want to place an action after\n   * an action without priority, negative numbers can be used.\n   */\n  priority?: number;\n\n  [key: string]: any;\n}\n\n/** Describes a data grid action control for multiple items. */\nexport interface BulkActionControl extends ActionControl {\n  /**\n   * A callback function.\n   * @param selectedItemIds The list of ids of the selected items.\n   * @param reload The function to call, if you want to reload the grid.\n   */\n  callback(selectedItemIds: string[], reload: () => void): void;\n\n  /**\n   * Determines if the action should be shown for given selected items (if not defined, the action will be shown always).\n   * @param selectedItemIds The list of ids of the selected items for which the action is supposed to be performed.\n   */\n  showIf?(selectedItemIds: string[]): boolean;\n}\n\n/** Describes a data grid action control for the header. */\nexport interface HeaderActionControl extends ActionControl {\n  /**\n   * Custom template can be provided. If no template is provided,\n   * the default headerActionControl template is used.\n   */\n  template?: TemplateRef<any>;\n\n  /**\n   * A callback function.\n   */\n  callback(): void;\n\n  /**\n   * Determines if the action should be shown.\n   */\n  showIf?(): boolean;\n}\n\n/** Predefined types of actions. */\nexport enum BuiltInActionType {\n  /** Edit built-in action. */\n  Edit = 'EDIT',\n\n  /** Delete built-in action. */\n  Delete = 'DELETE',\n\n  /** Export built-in action. */\n  Export = 'EXPORT'\n}\n\n/**\n * Allows to attach action controls to specified grids.\n */\nexport interface ActionControlHook {\n  /**\n   * The action control(s) that will be attached to the grid.\n   */\n  actionControls: ActionControl | ActionControl[];\n  /**\n   * A functions that determines to which grid(s) the action control(s) will be attached.\n   * Not providing a function results in the actions control(s) not being attached to any grid.\n   */\n  matchesGrid: (\n    route: ActivatedRoute,\n    context?: GridConfigContext\n  ) => boolean | Promise<boolean> | Observable<boolean>;\n}\n\n/**\n * Factory to implement in order to add action controls from an extension.\n */\nexport type ActionControlFactory = ExtensionFactory<ActionControlHook>;\n\n/**\n * Defines an interface for a filter chip object, which represents a filter applied to a column.\n */\nexport interface FilterChip {\n  /**\n   * The actual value that the chip will hold.\n   * It can be just a string or a more complex object like\n   * {id: 123, name: Test, value: test}.\n   */\n  value: any;\n\n  /**\n   * The value that the chip will display in the dropdown.\n   */\n  displayValue: string;\n\n  /**\n   * Optional label that will be displayed if filter chips are separated into multiple groups.\n   */\n  label?: string;\n\n  /** An optional property that holds the path to the chip value in the externalFilterQuery. */\n  path?: string[];\n\n  /**\n   * An optional property that holds the form value taken from the column configuration.\n   */\n  externalFilterQuery?: any;\n\n  /**\n   * An optional property that holds the formly filtering configuration for the column that this filter is applied to.\n   */\n  filteringConfig?: FormlyColumnFilteringConfig;\n\n  /** An optional property that holds a string to search for. */\n  filterPredicate?: string;\n\n  /**\n   * The name of the column that this filter is applied to.\n   */\n  columnName: string | SpecialColumnName;\n\n  /**\n   * An optional function to remove this filter from the column.\n   * If not provided will set default removal function that will reduce the external query by removing the object that is resolved by the path set in the FilterChip.\n   * @returns An object defined by the `FilterChip` type, including the `columnName` and  updated `externalFilterQuery` or 'filterPredicate' properties.\n   * The returned object may also include additional properties defined by the `FilterChip` type as partials.\n   */\n  remove?: () => PartialFilterChipRemovalType;\n}\n\n/**\n * Represents a partial filter chip with either 'columnName' and 'externalFilterQuery' or 'columnName' and 'filterPredicate'.\n * @typedef {Object} PartialFilterChipRemovalType\n * @property {string} columnName - The column name for the filter chip.\n * @property {any} [externalFilterQuery] - The external filter query for the chip used for complex filters.\n * @property {any} [filterPredicate] - The filtering predicate for the chip used for simple filters with client-side filtering.\n * @property {...FilterChip} [optionalProperties] - Optional properties from the FilterChip type.\n */\nexport type PartialFilterChipRemovalType = (\n  | Required<Pick<FilterChip, 'columnName' | 'externalFilterQuery'>>\n  | Required<Pick<FilterChip, 'columnName' | 'filterPredicate'>>\n) &\n  Partial<FilterChip>;\n\n/**\n * Represents a partial filter chip with required properties 'displayValue' and 'value'.\n * @typedef {Object} PartialFilterChipGenerationType\n * @property {string} displayValue - The display value for the filter chip.\n * @property {any} value - The value for the filter chip.\n * @property {...FilterChip} [optionalProperties] - Optional properties from the FilterChip type.\n */\nexport type PartialFilterChipGenerationType = Required<Pick<FilterChip, 'displayValue' | 'value'>> &\n  Partial<FilterChip>;\n\n/**\n * Defines an interface for a mapper function that maps a `FormlyFieldConfig` to a `FilterChip`.\n */\nexport interface FilterMapper {\n  /**\n   * The type or types of the `FormlyFieldConfig` that this mapper applies to.\n   */\n  fieldType: string[] | string;\n\n  /**\n   * Maps a `FormlyFieldConfig` and a `FilterChip` to an `Observable` of a `FilterChip`.\n   *\n   * This function extends the provided `FilterChip` object with additional properties based on the information in the `FormlyFieldConfig`.\n   * The mapping process depends on the specific implementation of the `FilterMapper`.\n   *\n   * @param field - The `FormlyFieldConfig` to map.\n   * @param filter - The `FilterChip` to map.\n   * @returns An `Observable` that emits the mapped `FilterChip`.\n   * If undefined is returned an error is thrown and the chip is not visualized.\n   *\n   * ```typescript\n   * // Example implementation of `map` function in a `FilterMapper`\n   * map(field: FormlyFieldConfig, filter: FilterChip): Observable<FilterChip> {\n   *   if (this.fieldType.includes(field.type.toString())) {\n   *     return toObservable(field.templateOptions.options).pipe(\n   *       map(options => {\n   *         const object = options.find(option => option.value === get(filter.externalFilterQuery, filter.path));\n   *         return {\n   *           ...filter,\n   *           value: object,\n   *           displayValue: object?.label\n   *         };\n   *       })\n   *     );\n   *   }\n   * }\n   * ```\n   */\n  map: (field: FormlyFieldConfig, filter: FilterChip) => Observable<FilterChip>;\n}\n"]}
@@ -43,7 +43,8 @@ export class DataGridService {
43
43
  const customColumns = config.columns
44
44
  .filter(col => col.custom)
45
45
  .map((col) => new CustomColumn(col));
46
- const allColumns = [...columns, ...customColumns];
46
+ // Avoid config properties to be applied to the original column object by creating shallow copy of columns
47
+ const allColumns = [...columns.map(col => ({ ...col })), ...customColumns];
47
48
  noConfigColumns = allColumns.filter(col => !config.columns.some(configCol => col.name === configCol.name));
48
49
  config.columns.forEach(({ visible, name, sortOrder, filter }) => {
49
50
  const columnToReorder = allColumns.find(col => col.name === name);
@@ -52,6 +53,8 @@ export class DataGridService {
52
53
  columnToReorder.sortOrder = sortOrder;
53
54
  columnToReorder.externalFilterQuery =
54
55
  columnToReorder.externalFilterQuery ?? filter?.externalFilterQuery;
56
+ columnToReorder.filterPredicate =
57
+ columnToReorder.filterPredicate ?? filter?.filterPredicate;
55
58
  reOrderedColumns.push(columnToReorder);
56
59
  }
57
60
  });
@@ -97,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
97
100
  providedIn: 'root'
98
101
  }]
99
102
  }], ctorParameters: () => [{ type: i1.UserPreferencesService }] });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.service.js","sourceRoot":"","sources":["../../../../core/data-grid/data-grid.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { QueriesUtil } from '@c8y/client';\nimport { assign, forEach, get, identity, transform } from 'lodash-es';\nimport { from, isObservable, Observable, of } from 'rxjs';\nimport { map, share, take, withLatestFrom } from 'rxjs/operators';\nimport { UserPreferencesService } from '../common/user-preferences/user-preferences.service';\nimport { CustomColumn } from './column/custom.column';\nimport { Column, CustomColumnConfig, GridConfig } from './data-grid.model';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class DataGridService {\n  protected DEFAULT_PAGE_SIZE = 20;\n\n  protected queriesUtil: QueriesUtil;\n\n  constructor(protected userPreferencesService: UserPreferencesService) {\n    this.queriesUtil = new QueriesUtil();\n  }\n\n  clearConfig(key: string) {\n    localStorage.removeItem(key);\n  }\n\n  getConfig$(key: string): Observable<GridConfig> {\n    return this.userPreferencesService.get(key).pipe(\n      map(\n        config =>\n          config || {\n            columns: [],\n            pagination: { pageSize: this.DEFAULT_PAGE_SIZE, currentPage: 1 }\n          }\n      )\n    );\n  }\n\n  saveConfig$(config: GridConfig, key: string): Observable<GridConfig> {\n    return from(this.userPreferencesService.set(key, config));\n  }\n\n  getUserConfiguredColumns$(columns: Column[] | Observable<Column[]>, storageKey?: string) {\n    return this.getConfig$(storageKey).pipe(\n      withLatestFrom(\n        isObservable(columns) ? columns : (of(columns) as unknown as Observable<Column[]>)\n      ),\n      map(([config, cols]) => this.applyConfigToColumns(config, cols, storageKey)),\n      take(1),\n      share()\n    );\n  }\n\n  getQueryObj(columns: Column[], defaultFilter = {}): any {\n    return transform(columns, (query, column) => this.extendQueryByColumn(query, column), {\n      __filter: {},\n      __orderby: [],\n      ...defaultFilter\n    });\n  }\n\n  applyConfigToColumns(config: GridConfig, columns: Column[], storageKey?: string): Column[] {\n    if (config?.columns?.length > 0) {\n      const reOrderedColumns = [];\n      let noConfigColumns = [];\n      try {\n        const customColumns = config.columns\n          .filter(col => (col as CustomColumnConfig).custom)\n          .map((col: CustomColumnConfig) => new CustomColumn(col));\n\n        const allColumns = [...columns, ...customColumns];\n\n        noConfigColumns = allColumns.filter(\n          col => !config.columns.some(configCol => col.name === configCol.name)\n        );\n        config.columns.forEach(({ visible, name, sortOrder, filter }) => {\n          const columnToReorder = allColumns.find(col => col.name === name);\n          if (columnToReorder) {\n            columnToReorder.visible = visible;\n            columnToReorder.sortOrder = sortOrder;\n            columnToReorder.externalFilterQuery =\n              columnToReorder.externalFilterQuery ?? filter?.externalFilterQuery;\n            reOrderedColumns.push(columnToReorder);\n          }\n        });\n      } catch (ex) {\n        this.clearConfig(storageKey);\n      }\n      return [...reOrderedColumns, ...noConfigColumns];\n    }\n    return columns;\n  }\n\n  private extendQueryByColumn(query: any, column: Column): void {\n    if (column.filterable && column.externalFilterQuery) {\n      const getFilter = column.filteringConfig.getFilter || identity;\n      const queryObj = getFilter(column.externalFilterQuery);\n\n      if (queryObj.__or) {\n        query.__filter.__and = query.__filter.__and || [];\n        query.__filter.__and.push(queryObj);\n      } else if (queryObj.__and && get(query, '__filter.__and')) {\n        queryObj.__and.map(obj => query.__filter.__and.push(obj));\n      } else {\n        assign(query.__filter, queryObj);\n      }\n    }\n\n    if (column.sortable && column.sortOrder) {\n      const cs = {};\n      forEach(column.sortingConfig.pathSortingConfigs, pathSortingConfig => {\n        cs[pathSortingConfig.path] =\n          (column.sortOrder === 'asc' ? 1 : -1) * (pathSortingConfig.sortOrderModifier || 1);\n      });\n      query.__orderby.push(cs);\n    }\n    return query;\n  }\n}\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.service.js","sourceRoot":"","sources":["../../../../core/data-grid/data-grid.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { QueriesUtil } from '@c8y/client';\nimport { assign, forEach, get, identity, transform } from 'lodash-es';\nimport { from, isObservable, Observable, of } from 'rxjs';\nimport { map, share, take, withLatestFrom } from 'rxjs/operators';\nimport { UserPreferencesService } from '../common/user-preferences/user-preferences.service';\nimport { CustomColumn } from './column/custom.column';\nimport { Column, CustomColumnConfig, GridConfig } from './data-grid.model';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class DataGridService {\n  protected DEFAULT_PAGE_SIZE = 20;\n\n  protected queriesUtil: QueriesUtil;\n\n  constructor(protected userPreferencesService: UserPreferencesService) {\n    this.queriesUtil = new QueriesUtil();\n  }\n\n  clearConfig(key: string) {\n    localStorage.removeItem(key);\n  }\n\n  getConfig$(key: string): Observable<GridConfig> {\n    return this.userPreferencesService.get(key).pipe(\n      map(\n        config =>\n          config || {\n            columns: [],\n            pagination: { pageSize: this.DEFAULT_PAGE_SIZE, currentPage: 1 }\n          }\n      )\n    );\n  }\n\n  saveConfig$(config: GridConfig, key: string): Observable<GridConfig> {\n    return from(this.userPreferencesService.set(key, config));\n  }\n\n  getUserConfiguredColumns$(columns: Column[] | Observable<Column[]>, storageKey?: string) {\n    return this.getConfig$(storageKey).pipe(\n      withLatestFrom(\n        isObservable(columns) ? columns : (of(columns) as unknown as Observable<Column[]>)\n      ),\n      map(([config, cols]) => this.applyConfigToColumns(config, cols, storageKey)),\n      take(1),\n      share()\n    );\n  }\n\n  getQueryObj(columns: Column[], defaultFilter = {}): any {\n    return transform(columns, (query, column) => this.extendQueryByColumn(query, column), {\n      __filter: {},\n      __orderby: [],\n      ...defaultFilter\n    });\n  }\n\n  applyConfigToColumns(config: GridConfig, columns: Column[], storageKey?: string): Column[] {\n    if (config?.columns?.length > 0) {\n      const reOrderedColumns = [];\n      let noConfigColumns = [];\n      try {\n        const customColumns = config.columns\n          .filter(col => (col as CustomColumnConfig).custom)\n          .map((col: CustomColumnConfig) => new CustomColumn(col));\n\n        // Avoid config properties to be applied to the original column object by creating shallow copy of columns\n        const allColumns = [...columns.map(col => ({ ...col })), ...customColumns];\n\n        noConfigColumns = allColumns.filter(\n          col => !config.columns.some(configCol => col.name === configCol.name)\n        );\n        config.columns.forEach(({ visible, name, sortOrder, filter }) => {\n          const columnToReorder = allColumns.find(col => col.name === name);\n          if (columnToReorder) {\n            columnToReorder.visible = visible;\n            columnToReorder.sortOrder = sortOrder;\n            columnToReorder.externalFilterQuery =\n              columnToReorder.externalFilterQuery ?? filter?.externalFilterQuery;\n            columnToReorder.filterPredicate =\n              columnToReorder.filterPredicate ?? filter?.filterPredicate;\n            reOrderedColumns.push(columnToReorder);\n          }\n        });\n      } catch (ex) {\n        this.clearConfig(storageKey);\n      }\n      return [...reOrderedColumns, ...noConfigColumns];\n    }\n    return columns;\n  }\n\n  private extendQueryByColumn(query: any, column: Column): void {\n    if (column.filterable && column.externalFilterQuery) {\n      const getFilter = column.filteringConfig.getFilter || identity;\n      const queryObj = getFilter(column.externalFilterQuery);\n\n      if (queryObj.__or) {\n        query.__filter.__and = query.__filter.__and || [];\n        query.__filter.__and.push(queryObj);\n      } else if (queryObj.__and && get(query, '__filter.__and')) {\n        queryObj.__and.map(obj => query.__filter.__and.push(obj));\n      } else {\n        assign(query.__filter, queryObj);\n      }\n    }\n\n    if (column.sortable && column.sortOrder) {\n      const cs = {};\n      forEach(column.sortingConfig.pathSortingConfigs, pathSortingConfig => {\n        cs[pathSortingConfig.path] =\n          (column.sortOrder === 'asc' ? 1 : -1) * (pathSortingConfig.sortOrderModifier || 1);\n      });\n      query.__orderby.push(cs);\n    }\n    return query;\n  }\n}\n"]}
@@ -11,12 +11,12 @@ export class NavigatorBottomComponent {
11
11
  this.hasHidePoweredSet$ = this.bottomService.hasHidePoweredSet();
12
12
  }
13
13
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavigatorBottomComponent, deps: [{ token: i1.NavigatorBottomService }], target: i0.ɵɵFactoryTarget.Component }); }
14
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: NavigatorBottomComponent, isStandalone: true, selector: "c8y-navigator-bottom", host: { classAttribute: "navigator-slot-bottom" }, ngImport: i0, template: "<div\n class=\"d-flex gap-8 {{!(hasCustomNavigatorLogoSet$ | async) ? 'c8y-logo' : ''}}\"\n *ngIf=\"!(hasCustomNavigatorLogoSet$ | async); else branded\"\n>\n <p\n *ngIf=\"!(hasHidePoweredSet$ | async)\"\n class=\"powered-by text-left a-s-end\"\n translate\n >\n powered by\n </p>\n <a href=\"https://cumulocity.com\" target=\"_blank\" title=\"Cumulocity\" class=\"tenant-brand\"></a>\n</div>\n<ng-template #branded>\n <div class=\"logo-spacer\"></div>\n <div class=\"tenant-brand\"></div>\n <p\n class=\"powered-by text-center a-s-center\"\n *ngIf=\"!(hasHidePoweredSet$ | async)\"\n translate\n >\n powered by <a href=\"https://cumulocity.com\" target=\"_blank\">Cumulocity</a>\n </p>\n <div class=\"logo-spacer\"></div>\n</ng-template>\n", dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: C8yTranslateDirective, selector: "[translate],[ngx-translate]" }] }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: NavigatorBottomComponent, isStandalone: true, selector: "c8y-navigator-bottom", host: { classAttribute: "navigator-slot-bottom" }, ngImport: i0, template: "<div\n class=\"d-flex gap-8 {{!(hasCustomNavigatorLogoSet$ | async) ? 'c8y-logo' : ''}}\"\n *ngIf=\"!(hasCustomNavigatorLogoSet$ | async); else branded\"\n>\n <p\n *ngIf=\"!(hasHidePoweredSet$ | async)\"\n class=\"powered-by text-left a-s-end\"\n translate\n >\n powered by`KEEP_ORIGINAL`\n </p>\n <a href=\"https://cumulocity.com\" target=\"_blank\" title=\"Cumulocity\" class=\"tenant-brand\"></a>\n</div>\n<ng-template #branded>\n <div class=\"logo-spacer\"></div>\n <div class=\"tenant-brand\"></div>\n <p\n class=\"powered-by text-center a-s-center\"\n *ngIf=\"!(hasHidePoweredSet$ | async)\"\n translate\n >\n powered by <a href=\"https://cumulocity.com\" target=\"_blank\">Cumulocity</a>`KEEP_ORIGINAL`\n </p>\n <div class=\"logo-spacer\"></div>\n</ng-template>\n", dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: C8yTranslateDirective, selector: "[translate],[ngx-translate]" }] }); }
15
15
  }
16
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavigatorBottomComponent, decorators: [{
17
17
  type: Component,
18
18
  args: [{ selector: 'c8y-navigator-bottom', host: {
19
19
  class: 'navigator-slot-bottom'
20
- }, standalone: true, imports: [AsyncPipe, NgIf, C8yTranslateDirective], template: "<div\n class=\"d-flex gap-8 {{!(hasCustomNavigatorLogoSet$ | async) ? 'c8y-logo' : ''}}\"\n *ngIf=\"!(hasCustomNavigatorLogoSet$ | async); else branded\"\n>\n <p\n *ngIf=\"!(hasHidePoweredSet$ | async)\"\n class=\"powered-by text-left a-s-end\"\n translate\n >\n powered by\n </p>\n <a href=\"https://cumulocity.com\" target=\"_blank\" title=\"Cumulocity\" class=\"tenant-brand\"></a>\n</div>\n<ng-template #branded>\n <div class=\"logo-spacer\"></div>\n <div class=\"tenant-brand\"></div>\n <p\n class=\"powered-by text-center a-s-center\"\n *ngIf=\"!(hasHidePoweredSet$ | async)\"\n translate\n >\n powered by <a href=\"https://cumulocity.com\" target=\"_blank\">Cumulocity</a>\n </p>\n <div class=\"logo-spacer\"></div>\n</ng-template>\n" }]
20
+ }, standalone: true, imports: [AsyncPipe, NgIf, C8yTranslateDirective], template: "<div\n class=\"d-flex gap-8 {{!(hasCustomNavigatorLogoSet$ | async) ? 'c8y-logo' : ''}}\"\n *ngIf=\"!(hasCustomNavigatorLogoSet$ | async); else branded\"\n>\n <p\n *ngIf=\"!(hasHidePoweredSet$ | async)\"\n class=\"powered-by text-left a-s-end\"\n translate\n >\n powered by`KEEP_ORIGINAL`\n </p>\n <a href=\"https://cumulocity.com\" target=\"_blank\" title=\"Cumulocity\" class=\"tenant-brand\"></a>\n</div>\n<ng-template #branded>\n <div class=\"logo-spacer\"></div>\n <div class=\"tenant-brand\"></div>\n <p\n class=\"powered-by text-center a-s-center\"\n *ngIf=\"!(hasHidePoweredSet$ | async)\"\n translate\n >\n powered by <a href=\"https://cumulocity.com\" target=\"_blank\">Cumulocity</a>`KEEP_ORIGINAL`\n </p>\n <div class=\"logo-spacer\"></div>\n</ng-template>\n" }]
21
21
  }], ctorParameters: () => [{ type: i1.NavigatorBottomService }] });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdG9yLWJvdHRvbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9jb3JlL25hdmlnYXRvci9uYXZpZ2F0b3ItYm90dG9tL25hdmlnYXRvci1ib3R0b20uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vY29yZS9uYXZpZ2F0b3IvbmF2aWdhdG9yLWJvdHRvbS9uYXZpZ2F0b3ItYm90dG9tLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDcEUsT0FBTyxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNsRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxZQUFZLENBQUM7OztBQVduRCxNQUFNLE9BQU8sd0JBQXdCO0lBSW5DLFlBQW9CLGFBQXFDO1FBQXJDLGtCQUFhLEdBQWIsYUFBYSxDQUF3QjtRQUh6RCwrQkFBMEIsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLHlCQUF5QixFQUFFLENBQUM7UUFDNUUsdUJBQWtCLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBRUEsQ0FBQzs4R0FKbEQsd0JBQXdCO2tHQUF4Qix3QkFBd0IsbUlDZHJDLDB3QkF5QkEsdUNEYlksU0FBUyw4Q0FBRSxJQUFJLDZGQUFFLHFCQUFxQjs7MkZBRXJDLHdCQUF3QjtrQkFUcEMsU0FBUzsrQkFDRSxzQkFBc0IsUUFFMUI7d0JBQ0osS0FBSyxFQUFFLHVCQUF1QjtxQkFDL0IsY0FDVyxJQUFJLFdBQ1AsQ0FBQyxTQUFTLEVBQUUsSUFBSSxFQUFFLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOYXZpZ2F0b3JCb3R0b21TZXJ2aWNlIH0gZnJvbSAnLi9uYXZpZ2F0b3ItYm90dG9tLnNlcnZpY2UnO1xuaW1wb3J0IHsgQXN5bmNQaXBlLCBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEM4eVRyYW5zbGF0ZURpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2kxOG4nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjOHktbmF2aWdhdG9yLWJvdHRvbScsXG4gIHRlbXBsYXRlVXJsOiAnLi9uYXZpZ2F0b3ItYm90dG9tLmNvbXBvbmVudC5odG1sJyxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnbmF2aWdhdG9yLXNsb3QtYm90dG9tJ1xuICB9LFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQXN5bmNQaXBlLCBOZ0lmLCBDOHlUcmFuc2xhdGVEaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIE5hdmlnYXRvckJvdHRvbUNvbXBvbmVudCB7XG4gIGhhc0N1c3RvbU5hdmlnYXRvckxvZ29TZXQkID0gdGhpcy5ib3R0b21TZXJ2aWNlLmhhc0N1c3RvbU5hdmlnYXRvckxvZ29TZXQoKTtcbiAgaGFzSGlkZVBvd2VyZWRTZXQkID0gdGhpcy5ib3R0b21TZXJ2aWNlLmhhc0hpZGVQb3dlcmVkU2V0KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBib3R0b21TZXJ2aWNlOiBOYXZpZ2F0b3JCb3R0b21TZXJ2aWNlKSB7fVxufVxuIiwiPGRpdlxuICBjbGFzcz1cImQtZmxleCBnYXAtOCB7eyEoaGFzQ3VzdG9tTmF2aWdhdG9yTG9nb1NldCQgfCBhc3luYykgPyAnYzh5LWxvZ28nIDogJyd9fVwiXG4gICpuZ0lmPVwiIShoYXNDdXN0b21OYXZpZ2F0b3JMb2dvU2V0JCB8IGFzeW5jKTsgZWxzZSBicmFuZGVkXCJcbj5cbiAgPHBcbiAgICAqbmdJZj1cIiEoaGFzSGlkZVBvd2VyZWRTZXQkIHwgYXN5bmMpXCJcbiAgICBjbGFzcz1cInBvd2VyZWQtYnkgdGV4dC1sZWZ0IGEtcy1lbmRcIlxuICAgIHRyYW5zbGF0ZVxuICA+XG4gICAgcG93ZXJlZCBieVxuICA8L3A+XG4gIDxhIGhyZWY9XCJodHRwczovL2N1bXVsb2NpdHkuY29tXCIgdGFyZ2V0PVwiX2JsYW5rXCIgdGl0bGU9XCJDdW11bG9jaXR5XCIgY2xhc3M9XCJ0ZW5hbnQtYnJhbmRcIj48L2E+XG48L2Rpdj5cbjxuZy10ZW1wbGF0ZSAjYnJhbmRlZD5cbiAgPGRpdiBjbGFzcz1cImxvZ28tc3BhY2VyXCI+PC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJ0ZW5hbnQtYnJhbmRcIj48L2Rpdj5cbiAgPHBcbiAgICBjbGFzcz1cInBvd2VyZWQtYnkgdGV4dC1jZW50ZXIgYS1zLWNlbnRlclwiXG4gICAgKm5nSWY9XCIhKGhhc0hpZGVQb3dlcmVkU2V0JCB8IGFzeW5jKVwiXG4gICAgdHJhbnNsYXRlXG4gID5cbiAgICBwb3dlcmVkIGJ5IDxhIGhyZWY9XCJodHRwczovL2N1bXVsb2NpdHkuY29tXCIgdGFyZ2V0PVwiX2JsYW5rXCI+Q3VtdWxvY2l0eTwvYT5cbiAgPC9wPlxuICA8ZGl2IGNsYXNzPVwibG9nby1zcGFjZXJcIj48L2Rpdj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdG9yLWJvdHRvbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9jb3JlL25hdmlnYXRvci9uYXZpZ2F0b3ItYm90dG9tL25hdmlnYXRvci1ib3R0b20uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vY29yZS9uYXZpZ2F0b3IvbmF2aWdhdG9yLWJvdHRvbS9uYXZpZ2F0b3ItYm90dG9tLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDcEUsT0FBTyxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNsRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxZQUFZLENBQUM7OztBQVduRCxNQUFNLE9BQU8sd0JBQXdCO0lBSW5DLFlBQW9CLGFBQXFDO1FBQXJDLGtCQUFhLEdBQWIsYUFBYSxDQUF3QjtRQUh6RCwrQkFBMEIsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLHlCQUF5QixFQUFFLENBQUM7UUFDNUUsdUJBQWtCLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBRUEsQ0FBQzs4R0FKbEQsd0JBQXdCO2tHQUF4Qix3QkFBd0IsbUlDZHJDLHd5QkF5QkEsdUNEYlksU0FBUyw4Q0FBRSxJQUFJLDZGQUFFLHFCQUFxQjs7MkZBRXJDLHdCQUF3QjtrQkFUcEMsU0FBUzsrQkFDRSxzQkFBc0IsUUFFMUI7d0JBQ0osS0FBSyxFQUFFLHVCQUF1QjtxQkFDL0IsY0FDVyxJQUFJLFdBQ1AsQ0FBQyxTQUFTLEVBQUUsSUFBSSxFQUFFLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOYXZpZ2F0b3JCb3R0b21TZXJ2aWNlIH0gZnJvbSAnLi9uYXZpZ2F0b3ItYm90dG9tLnNlcnZpY2UnO1xuaW1wb3J0IHsgQXN5bmNQaXBlLCBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEM4eVRyYW5zbGF0ZURpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2kxOG4nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjOHktbmF2aWdhdG9yLWJvdHRvbScsXG4gIHRlbXBsYXRlVXJsOiAnLi9uYXZpZ2F0b3ItYm90dG9tLmNvbXBvbmVudC5odG1sJyxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnbmF2aWdhdG9yLXNsb3QtYm90dG9tJ1xuICB9LFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQXN5bmNQaXBlLCBOZ0lmLCBDOHlUcmFuc2xhdGVEaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIE5hdmlnYXRvckJvdHRvbUNvbXBvbmVudCB7XG4gIGhhc0N1c3RvbU5hdmlnYXRvckxvZ29TZXQkID0gdGhpcy5ib3R0b21TZXJ2aWNlLmhhc0N1c3RvbU5hdmlnYXRvckxvZ29TZXQoKTtcbiAgaGFzSGlkZVBvd2VyZWRTZXQkID0gdGhpcy5ib3R0b21TZXJ2aWNlLmhhc0hpZGVQb3dlcmVkU2V0KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBib3R0b21TZXJ2aWNlOiBOYXZpZ2F0b3JCb3R0b21TZXJ2aWNlKSB7fVxufVxuIiwiPGRpdlxuICBjbGFzcz1cImQtZmxleCBnYXAtOCB7eyEoaGFzQ3VzdG9tTmF2aWdhdG9yTG9nb1NldCQgfCBhc3luYykgPyAnYzh5LWxvZ28nIDogJyd9fVwiXG4gICpuZ0lmPVwiIShoYXNDdXN0b21OYXZpZ2F0b3JMb2dvU2V0JCB8IGFzeW5jKTsgZWxzZSBicmFuZGVkXCJcbj5cbiAgPHBcbiAgICAqbmdJZj1cIiEoaGFzSGlkZVBvd2VyZWRTZXQkIHwgYXN5bmMpXCJcbiAgICBjbGFzcz1cInBvd2VyZWQtYnkgdGV4dC1sZWZ0IGEtcy1lbmRcIlxuICAgIHRyYW5zbGF0ZVxuICA+XG4gICAgcG93ZXJlZCBieWBLRUVQX09SSUdJTkFMYFxuICA8L3A+XG4gIDxhIGhyZWY9XCJodHRwczovL2N1bXVsb2NpdHkuY29tXCIgdGFyZ2V0PVwiX2JsYW5rXCIgdGl0bGU9XCJDdW11bG9jaXR5XCIgY2xhc3M9XCJ0ZW5hbnQtYnJhbmRcIj48L2E+XG48L2Rpdj5cbjxuZy10ZW1wbGF0ZSAjYnJhbmRlZD5cbiAgPGRpdiBjbGFzcz1cImxvZ28tc3BhY2VyXCI+PC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJ0ZW5hbnQtYnJhbmRcIj48L2Rpdj5cbiAgPHBcbiAgICBjbGFzcz1cInBvd2VyZWQtYnkgdGV4dC1jZW50ZXIgYS1zLWNlbnRlclwiXG4gICAgKm5nSWY9XCIhKGhhc0hpZGVQb3dlcmVkU2V0JCB8IGFzeW5jKVwiXG4gICAgdHJhbnNsYXRlXG4gID5cbiAgICBwb3dlcmVkIGJ5IDxhIGhyZWY9XCJodHRwczovL2N1bXVsb2NpdHkuY29tXCIgdGFyZ2V0PVwiX2JsYW5rXCI+Q3VtdWxvY2l0eTwvYT5gS0VFUF9PUklHSU5BTGBcbiAgPC9wPlxuICA8ZGl2IGNsYXNzPVwibG9nby1zcGFjZXJcIj48L2Rpdj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
@@ -509,6 +509,8 @@ class AlarmsViewService {
509
509
  return `/device/${contextData.contextData.id}${detailUrl}`;
510
510
  case ViewContext.Group:
511
511
  return `/group/${contextData.contextData.id}${detailUrl}`;
512
+ case ViewContext.Simulators:
513
+ return `/simulators/${contextData.contextData.id}${detailUrl}`;
512
514
  default:
513
515
  return detailUrl;
514
516
  }