@c8y/ngx-components 1020.0.19 → 1020.0.22
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.
- package/alarms/alarms-list.component.d.ts.map +1 -1
- package/core/data-grid/column/expandable-row-column/expandable.cell-renderer.component.d.ts +2 -1
- package/core/data-grid/column/expandable-row-column/expandable.cell-renderer.component.d.ts.map +1 -1
- package/core/i18n/load-locale.d.ts.map +1 -1
- package/esm2022/alarms/alarms-list.component.mjs +3 -4
- package/esm2022/core/data-grid/column/expandable-row-column/expandable.cell-renderer.component.mjs +14 -10
- package/esm2022/core/i18n/load-locale.mjs +4 -5
- package/fesm2022/c8y-ngx-components-alarms.mjs +2 -3
- package/fesm2022/c8y-ngx-components-alarms.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components.mjs +10 -7
- package/fesm2022/c8y-ngx-components.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"alarms-list.component.d.ts","sourceRoot":"","sources":["../../alarms/alarms-list.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EAEb,UAAU,EACV,YAAY,EAEZ,SAAS,EACT,SAAS,EAET,aAAa,EAEd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,cAAc,EAAiB,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACxE,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,YAAY,EAAW,MAAM,qBAAqB,CAAC;AACpG,OAAO,EAAE,eAAe,EAAE,UAAU,EAAsB,MAAM,MAAM,CAAC;AAUvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;;AAE1D,qBAIa,mBAAoB,YAAW,SAAS,EAAE,aAAa,EAAE,SAAS;IA0F3E,OAAO,CAAC,cAAc;IACtB,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,mBAAmB;IAC3B,OAAO,CAAC,MAAM;IA5FhB,QAAQ,CAAC,iBAAiB,0HAExB;IAEF;;OAEG;IAEH,MAAM,EAAE,WAAW,CAAC,MAAM,GAAG;QAAE,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAEhD;;OAEG;IAEH,YAAY,EAAE,YAAY,CAAY;IAEtC;;;OAGG;IAEH,iBAAiB;QACf;;WAEG;;QAEH;;;;WAIG;;QAEH;;;WAGG;;MAEH;IAEF;;;OAGG;IAEH,gBAAgB,UAAS;IAEzB;;;;;;;OAOG;IAEH,SAAS,UAAS;IAElB;;OAEG;IAEH,eAAe,uBAA8B;IAE7C;;OAEG;IAEH,sBAAsB,wBAA+B;IAErD;;OAEG;IACH,YAAY,0BAAqC;IACjD,iBAAiB,qBAA4B;IAG7C,kBAAkB,EAAE,UAAU,CAAC;IAE/B,WAAW,UAAS;IACpB;;;;OAIG;IACH,kBAAkB,UAAQ;IAC1B,OAAO,CAAC,QAAQ,CAAsC;IACtD,OAAO,CAAC,8BAA8B,CAAM;gBAGlC,cAAc,EAAE,cAAc,EAC9B,iBAAiB,EAAE,iBAAiB,EACpC,mBAAmB,EAAE,mBAAmB,EACxC,MAAM,EAAE,MAAM;IAKxB;;;;;;OAMG;IACH,kBAAkB,CAAC,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;
|
|
1
|
+
{"version":3,"file":"alarms-list.component.d.ts","sourceRoot":"","sources":["../../alarms/alarms-list.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EAEb,UAAU,EACV,YAAY,EAEZ,SAAS,EACT,SAAS,EAET,aAAa,EAEd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,cAAc,EAAiB,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACxE,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,YAAY,EAAW,MAAM,qBAAqB,CAAC;AACpG,OAAO,EAAE,eAAe,EAAE,UAAU,EAAsB,MAAM,MAAM,CAAC;AAUvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;;AAE1D,qBAIa,mBAAoB,YAAW,SAAS,EAAE,aAAa,EAAE,SAAS;IA0F3E,OAAO,CAAC,cAAc;IACtB,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,mBAAmB;IAC3B,OAAO,CAAC,MAAM;IA5FhB,QAAQ,CAAC,iBAAiB,0HAExB;IAEF;;OAEG;IAEH,MAAM,EAAE,WAAW,CAAC,MAAM,GAAG;QAAE,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAEhD;;OAEG;IAEH,YAAY,EAAE,YAAY,CAAY;IAEtC;;;OAGG;IAEH,iBAAiB;QACf;;WAEG;;QAEH;;;;WAIG;;QAEH;;;WAGG;;MAEH;IAEF;;;OAGG;IAEH,gBAAgB,UAAS;IAEzB;;;;;;;OAOG;IAEH,SAAS,UAAS;IAElB;;OAEG;IAEH,eAAe,uBAA8B;IAE7C;;OAEG;IAEH,sBAAsB,wBAA+B;IAErD;;OAEG;IACH,YAAY,0BAAqC;IACjD,iBAAiB,qBAA4B;IAG7C,kBAAkB,EAAE,UAAU,CAAC;IAE/B,WAAW,UAAS;IACpB;;;;OAIG;IACH,kBAAkB,UAAQ;IAC1B,OAAO,CAAC,QAAQ,CAAsC;IACtD,OAAO,CAAC,8BAA8B,CAAM;gBAGlC,cAAc,EAAE,cAAc,EAC9B,iBAAiB,EAAE,iBAAiB,EACpC,mBAAmB,EAAE,mBAAmB,EACxC,MAAM,EAAE,MAAM;IAKxB;;;;;;OAMG;IACH,kBAAkB,CAAC,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAS3F,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI;IAWzC,eAAe,IAAI,IAAI;IAavB,WAAW,IAAI,IAAI;IAKnB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIhC,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAQpC,OAAO,CAAC,+BAA+B;IAKvC,OAAO,CAAC,4BAA4B;yCAhKzB,mBAAmB;2CAAnB,mBAAmB;CA6K/B"}
|
|
@@ -11,7 +11,8 @@ export declare class ExpandableCellRendererComponent {
|
|
|
11
11
|
isExpanded: boolean;
|
|
12
12
|
loading: boolean;
|
|
13
13
|
destroyRef: DestroyRef;
|
|
14
|
-
constructor(context: CellRendererContext, dataGridComponent: DataGridComponent,
|
|
14
|
+
constructor(context: CellRendererContext, dataGridComponent: DataGridComponent, // forwardRef is needed because of circular dependency
|
|
15
|
+
cd: ChangeDetectorRef);
|
|
15
16
|
toggleExpand(): void;
|
|
16
17
|
static ɵfac: i0.ɵɵFactoryDeclaration<ExpandableCellRendererComponent, never>;
|
|
17
18
|
static ɵcmp: i0.ɵɵComponentDeclaration<ExpandableCellRendererComponent, "c8y-expandable-cell-renderer", never, {}, {}, never, never, false, never>;
|
package/core/data-grid/column/expandable-row-column/expandable.cell-renderer.component.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"expandable.cell-renderer.component.d.ts","sourceRoot":"","sources":["../../../../../core/data-grid/column/expandable-row-column/expandable.cell-renderer.component.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"expandable.cell-renderer.component.d.ts","sourceRoot":"","sources":["../../../../../core/data-grid/column/expandable-row-column/expandable.cell-renderer.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EAEjB,UAAU,EAIX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;;AAI9D,qBAiBa,+BAA+B;IAQjC,OAAO,EAAE,mBAAmB;IACiB,iBAAiB,EAAE,iBAAiB;IACxF,OAAO,CAAC,EAAE;IATZ,QAAQ,CAAC,QAAQ,aAAuB;IACxC,QAAQ,CAAC,MAAM,WAAqB;IACpC,UAAU,UAAS;IACnB,OAAO,UAAS;IAChB,UAAU,aAAsB;gBAGvB,OAAO,EAAE,mBAAmB,EACiB,iBAAiB,EAAE,iBAAiB,EAAE,sDAAsD;IACxI,EAAE,EAAE,iBAAiB;IAG/B,YAAY;yCAbD,+BAA+B;2CAA/B,+BAA+B;CA6B3C"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"load-locale.d.ts","sourceRoot":"","sources":["../../../core/i18n/load-locale.ts"],"names":[],"mappings":"AACA;;GAEG;AACH,wBAAgB,UAAU,CAAC,UAAU,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"load-locale.d.ts","sourceRoot":"","sources":["../../../core/i18n/load-locale.ts"],"names":[],"mappings":"AACA;;GAEG;AACH,wBAAgB,UAAU,CAAC,UAAU,EAAE,MAAM,oBAiB5C"}
|
|
@@ -91,9 +91,8 @@ export class AlarmsListComponent {
|
|
|
91
91
|
*/
|
|
92
92
|
activeRouteChanged(isActive, scrollAnchor, alarm) {
|
|
93
93
|
if (isActive) {
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
? scrollIntoViewIfNeeded()
|
|
94
|
+
scrollAnchor.element.nativeElement.scrollIntoViewIfNeeded
|
|
95
|
+
? scrollAnchor.element.nativeElement.scrollIntoViewIfNeeded()
|
|
97
96
|
: scrollAnchor.element.nativeElement.scrollIntoView();
|
|
98
97
|
this.activeAlarm$.next(alarm);
|
|
99
98
|
}
|
|
@@ -167,4 +166,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
167
166
|
type: ViewChild,
|
|
168
167
|
args: ['scrollWrapper']
|
|
169
168
|
}] } });
|
|
170
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarms-list.component.js","sourceRoot":"","sources":["../../../alarms/alarms-list.component.ts","../../../alarms/alarms-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router';\nimport { IAlarm, IResultList } from '@c8y/client';\nimport { ContextRouteService, ListItemComponent, LoadMoreMode, gettext } from '@c8y/ngx-components';\nimport { BehaviorSubject, Observable, Subject, fromEvent } from 'rxjs';\nimport {\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  map,\n  shareReplay,\n  switchMap,\n  takeUntil\n} from 'rxjs/operators';\nimport { AlarmsViewService } from './alarms-view.service';\n\n@Component({\n  selector: 'c8y-alarms-list',\n  templateUrl: './alarms-list.component.html'\n})\nexport class AlarmsListComponent implements OnChanges, AfterViewInit, OnDestroy {\n  readonly alarmBadgeTooltip = gettext(\n    'Number of occurrences`number of occurrences of alarm`. First occurrence {{ alarmFirstOccurrenceTime }} (device time).'\n  );\n\n  /**\n   * Input property for receiving a list of alarms.\n   */\n  @Input()\n  alarms: IResultList<IAlarm & { link?: string }>;\n\n  /**\n   * Input property for receiving load more mode.\n   */\n  @Input()\n  loadMoreMode: LoadMoreMode = 'hidden';\n\n  /**\n   * Defines options, how the alarm list should be navigated if a user\n   * clicks on an alarm.\n   */\n  @Input()\n  navigationOptions = {\n    /**\n     * Defines if the alarm should navigate to a detail view when clicked.\n     */\n    allowNavigationToAlarmsView: true,\n    /**\n     * Defines if the component should try to determine the context to navigate\n     * to the correct alarm detail view or not. If set to true, the component will\n     * not try to determine the context and will always navigate to the all alarms view.\n     */\n    alwaysNavigateToAllAlarms: false,\n    /**\n     * Defines if the cleared query parameter should be included in the navigation if\n     * the alarm is cleared.\n     */\n    includeClearedQueryParams: false\n  };\n\n  /**\n   * Controls the visibility of the loading bar\n   * When set to `false`, the alarm list is displayed. When set to `true`, the opacity of alarms list is changed and a loading bar is shown.\n   */\n  @Input()\n  isInitialLoading = false;\n\n  /**\n   * Controls the visibility and functionality of some components\n   * When set to `true`, means the list is displayed in a split view layout:\n   * the list on the first column and the selected record detail on the second column (the cockpit\n   * alarms view for example)\n   * When set to false, the list is displayed as a standalone component, opening the detail will\n   * redirect to the alarms\n   */\n  @Input()\n  splitView = false;\n\n  /**\n   * Emits an instance of a selected alarm when one is chosen from the list.\n   */\n  @Output()\n  onSelectedAlarm = new EventEmitter<IAlarm>();\n\n  /**\n   * Emits a boolean value indicating the scrolling state: true when the user starts scrolling, and false when the user reaches the top of the list.\n   */\n  @Output()\n  onScrollingStateChange = new EventEmitter<boolean>();\n\n  /**\n   * Current alarm or last alarm marked as active by the routerLinkActive directive.\n   */\n  activeAlarm$ = new BehaviorSubject<IAlarm>(null);\n  activeChildParam$ = new Observable<string>();\n\n  @ViewChild('scrollWrapper')\n  innerScrollWrapper: ElementRef;\n\n  isScrolling = false;\n  /**\n   * Determines whether the c8y-loading component should be displayed.\n   * The loading component is shown when no alarms are displayed in the view or when the request is initial,\n   * as we don't want to see empty space on alarm list during loading.\n   */\n  isEmptyListLoading = true;\n  private destroy$: Subject<void> = new Subject<void>();\n  private HIDE_INTERVAL_COUNTDOWN_SCROLL = 50;\n\n  constructor(\n    private activatedRoute: ActivatedRoute,\n    private alarmsViewService: AlarmsViewService,\n    private contextRouteService: ContextRouteService,\n    private router: Router\n  ) {\n    this.verifyIfFiltersMatchingAlarm();\n  }\n\n  /**\n   * Handles the change of the active route.\n   *\n   * @param isActive - A boolean indicating whether the route is active or not.\n   * @param scrollAnchor - The ListItemComponent used as a scroll anchor.\n   * @param alarm - The IAlarm object representing the active alarm.\n   */\n  activeRouteChanged(isActive: boolean, scrollAnchor: ListItemComponent, alarm: IAlarm): void {\n    if (isActive) {\n      const { scrollIntoViewIfNeeded } = scrollAnchor.element.nativeElement;\n      scrollIntoViewIfNeeded\n        ? scrollIntoViewIfNeeded()\n        : scrollAnchor.element.nativeElement.scrollIntoView();\n      this.activeAlarm$.next(alarm);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.alarms && changes.alarms) {\n      this.activeAlarm$.next(null);\n      this.isEmptyListLoading = !this.alarms?.data?.length;\n      this.alarms.data = this.alarms.data.map((alarm: IAlarm) => {\n        alarm.link = this.getRouterLink(alarm);\n        return alarm;\n      });\n    }\n  }\n\n  ngAfterViewInit(): void {\n    if (this.alarmsViewService.isIntervalRefresh()) {\n      const scrollElement = this.innerScrollWrapper.nativeElement;\n      fromEvent(scrollElement, 'scroll')\n        .pipe(takeUntil(this.destroy$), debounceTime(300))\n        .subscribe((event: Event) => {\n          const target = event.target as HTMLElement;\n          this.isScrolling = this.shouldCountdownIntervalBeHidden(target);\n          this.onScrollingStateChange.emit(this.isScrolling);\n        });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  onAlarmOpen(alarm: IAlarm): void {\n    this.onSelectedAlarm.emit(alarm);\n  }\n\n  getRouterLink(alarm: IAlarm): string {\n    if (this.navigationOptions.alwaysNavigateToAllAlarms) {\n      return this.alarmsViewService.getRouterLink(null, alarm);\n    }\n    const contextData = this.contextRouteService.getContextData(this.activatedRoute);\n    return this.alarmsViewService.getRouterLink(contextData, alarm);\n  }\n\n  private shouldCountdownIntervalBeHidden(target: HTMLElement): boolean {\n    const scrollTopPixels = target.scrollTop;\n    return scrollTopPixels > this.HIDE_INTERVAL_COUNTDOWN_SCROLL;\n  }\n\n  private verifyIfFiltersMatchingAlarm() {\n    this.activeChildParam$ = this.router.events.pipe(\n      filter(e => e instanceof NavigationEnd && this.activatedRoute.children.length > 0),\n      switchMap(() => this.activatedRoute.children[0].params),\n      map(params => params.id),\n      distinctUntilChanged(),\n      shareReplay(),\n      takeUntil(this.destroy$)\n    );\n\n    // done to get the first navigation\n    this.activeChildParam$.subscribe();\n  }\n}\n","<div\n  class=\"inner-scroll\"\n  [ngClass]=\"{ 'split-view__list bg-level-1': splitView, 'bg-component': !splitView }\"\n  data-cy=\"c8y-alarms-list\"\n  #scrollWrapper\n>\n  <div\n    class=\"flex-wrap flex-no-shrink sticky-top m-b-16\"\n    [ngClass]=\"{\n      'separator-bottom card-header p-b-0': splitView,\n      'd-flex fit-w separator-top-bottom widget-bar p-l-16 p-r-16':\n        !splitView && navigationOptions.allowNavigationToAlarmsView\n    }\"\n  >\n    <div\n      class=\"h4 card-title\"\n      *ngIf=\"splitView\"\n    >\n      {{ 'Alarms list' | translate }}\n    </div>\n    <div\n      [ngClass]=\"{ 'fit-w d-flex a-i-center gap-16': !splitView, 'fit-h-20 m-l-auto': splitView }\"\n    >\n      <ng-content></ng-content>\n    </div>\n    <!--  Loading -->\n    <div\n      class=\"fit-w overflow-hidden\"\n      [ngClass]=\"{ 'p-t-16': splitView }\"\n    >\n      <div\n        class=\"loading-bar\"\n        style=\"z-index: 101\"\n        [ngClass]=\"{ active: isInitialLoading && !isEmptyListLoading }\"\n      ></div>\n    </div>\n\n    <div\n      class=\"alert alert-warning\"\n      role=\"alert\"\n      translate\n      *ngIf=\"\n        !isEmptyListLoading &&\n        (activeChildParam$ | async) &&\n        (activeAlarm$ | async)?.id !== (activeChildParam$ | async)\n      \"\n    >\n      The selected alarm is not currently in the list, please change your filter.\n    </div>\n  </div>\n  <c8y-list-group\n    class=\"p-r-16 interactive\"\n    [ngStyle]=\"{ opacity: isInitialLoading && !isEmptyListLoading ? 0.2 : 1 }\"\n    style=\"transition: opacity 0.15s linear\"\n    data-cy=\"c8y-alarm-list--group\"\n  >\n    <c8y-li-timeline\n      class=\"pointer\"\n      role=\"button\"\n      data-cy=\"c8y-alarm-list--timeline-repeat\"\n      *c8yFor=\"let alarm of alarms; let i = index; loadMore: loadMoreMode\"\n      [routerLink]=\"navigationOptions.allowNavigationToAlarmsView ? alarm.link : null\"\n      routerLinkActive=\"active\"\n      queryParamsHandling=\"merge\"\n      (isActiveChange)=\"activeRouteChanged($event, liScrollAnchor, alarm)\"\n      (click)=\"onAlarmOpen(alarm)\"\n      [queryParams]=\"navigationOptions.includeClearedQueryParams ? { showCleared: alarm.status === 'CLEARED' } : {}\"\n    >\n      {{ alarm.time | c8yDate: 'mediumDate' }}\n      {{ alarm.time | c8yDate: 'mediumTime' }}\n      <c8y-li #liScrollAnchor>\n        <c8y-li-icon class=\"a-s-start\">\n          <div class=\"alarm-icons\">\n            <c8y-alarms-icon [alarm]=\"alarm\"></c8y-alarms-icon>\n          </div>\n          <button\n            class=\"btn-clean text-center\"\n            [attr.aria-label]=\"\n              alarmBadgeTooltip\n                | translate\n                  : { alarmFirstOccurrenceTime: alarm.firstOccurrenceTime | c8yDate: 'medium' }\n            \"\n            [tooltip]=\"\n              alarmBadgeTooltip\n                | translate\n                  : { alarmFirstOccurrenceTime: alarm.firstOccurrenceTime | c8yDate: 'medium' }\n            \"\n            placement=\"right\"\n            container=\"body\"\n            type=\"button\"\n            *ngIf=\"alarm.firstOccurrenceTime\"\n            (click)=\"$event.stopPropagation()\"\n            [delay]=\"500\"\n          >\n            <span\n              class=\"badge badge-info\"\n              *ngIf=\"alarm.count > 1\"\n            >\n              {{ alarm.count }}\n            </span>\n          </button>\n        </c8y-li-icon>\n        <c8y-li-body class=\"a-s-stretch\">\n          <div class=\"d-flex a-i-start fit-h\">\n            <div class=\"min-width-0 flex-grow\">\n              <p class=\"text-truncate-wrap p-b-4\">\n                {{ alarm.text | translate }}\n              </p>\n              <div class=\"d-flex\">\n                <p class=\"small text-muted flex-grow\">\n                  <i [c8yIcon]=\"'exchange'\"></i>\n                  {{ alarm.source.name }}\n                </p>\n              </div>\n            </div>\n          </div>\n        </c8y-li-body>\n      </c8y-li>\n    </c8y-li-timeline>\n    <c8y-loading *ngIf=\"isInitialLoading && isEmptyListLoading\"></c8y-loading>\n    <div\n      class=\"p-relative p-l-24\"\n      *ngIf=\"isEmptyListLoading && !isInitialLoading\"\n    >\n      <c8y-ui-empty-state\n        [icon]=\"'c8y-alert-idle'\"\n        [title]=\"'No alarms to display.' | translate\"\n        data-cy=\"alarm-list--empty-state\"\n      >\n        <p c8y-guide-docs>\n          <small\n            translate\n            ngNonBindable\n          >\n            Find out more in the\n            <a\n              c8y-guide-href=\"/docs/device-management-application/monitoring-and-controlling-devices/#working-with-alarms\"\n            >\n              user documentation\n            </a>\n            .\n          </small>\n        </p>\n      </c8y-ui-empty-state>\n    </div>\n  </c8y-list-group>\n</div>\n"]}
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarms-list.component.js","sourceRoot":"","sources":["../../../alarms/alarms-list.component.ts","../../../alarms/alarms-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router';\nimport { IAlarm, IResultList } from '@c8y/client';\nimport { ContextRouteService, ListItemComponent, LoadMoreMode, gettext } from '@c8y/ngx-components';\nimport { BehaviorSubject, Observable, Subject, fromEvent } from 'rxjs';\nimport {\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  map,\n  shareReplay,\n  switchMap,\n  takeUntil\n} from 'rxjs/operators';\nimport { AlarmsViewService } from './alarms-view.service';\n\n@Component({\n  selector: 'c8y-alarms-list',\n  templateUrl: './alarms-list.component.html'\n})\nexport class AlarmsListComponent implements OnChanges, AfterViewInit, OnDestroy {\n  readonly alarmBadgeTooltip = gettext(\n    'Number of occurrences`number of occurrences of alarm`. First occurrence {{ alarmFirstOccurrenceTime }} (device time).'\n  );\n\n  /**\n   * Input property for receiving a list of alarms.\n   */\n  @Input()\n  alarms: IResultList<IAlarm & { link?: string }>;\n\n  /**\n   * Input property for receiving load more mode.\n   */\n  @Input()\n  loadMoreMode: LoadMoreMode = 'hidden';\n\n  /**\n   * Defines options, how the alarm list should be navigated if a user\n   * clicks on an alarm.\n   */\n  @Input()\n  navigationOptions = {\n    /**\n     * Defines if the alarm should navigate to a detail view when clicked.\n     */\n    allowNavigationToAlarmsView: true,\n    /**\n     * Defines if the component should try to determine the context to navigate\n     * to the correct alarm detail view or not. If set to true, the component will\n     * not try to determine the context and will always navigate to the all alarms view.\n     */\n    alwaysNavigateToAllAlarms: false,\n    /**\n     * Defines if the cleared query parameter should be included in the navigation if\n     * the alarm is cleared.\n     */\n    includeClearedQueryParams: false\n  };\n\n  /**\n   * Controls the visibility of the loading bar\n   * When set to `false`, the alarm list is displayed. When set to `true`, the opacity of alarms list is changed and a loading bar is shown.\n   */\n  @Input()\n  isInitialLoading = false;\n\n  /**\n   * Controls the visibility and functionality of some components\n   * When set to `true`, means the list is displayed in a split view layout:\n   * the list on the first column and the selected record detail on the second column (the cockpit\n   * alarms view for example)\n   * When set to false, the list is displayed as a standalone component, opening the detail will\n   * redirect to the alarms\n   */\n  @Input()\n  splitView = false;\n\n  /**\n   * Emits an instance of a selected alarm when one is chosen from the list.\n   */\n  @Output()\n  onSelectedAlarm = new EventEmitter<IAlarm>();\n\n  /**\n   * Emits a boolean value indicating the scrolling state: true when the user starts scrolling, and false when the user reaches the top of the list.\n   */\n  @Output()\n  onScrollingStateChange = new EventEmitter<boolean>();\n\n  /**\n   * Current alarm or last alarm marked as active by the routerLinkActive directive.\n   */\n  activeAlarm$ = new BehaviorSubject<IAlarm>(null);\n  activeChildParam$ = new Observable<string>();\n\n  @ViewChild('scrollWrapper')\n  innerScrollWrapper: ElementRef;\n\n  isScrolling = false;\n  /**\n   * Determines whether the c8y-loading component should be displayed.\n   * The loading component is shown when no alarms are displayed in the view or when the request is initial,\n   * as we don't want to see empty space on alarm list during loading.\n   */\n  isEmptyListLoading = true;\n  private destroy$: Subject<void> = new Subject<void>();\n  private HIDE_INTERVAL_COUNTDOWN_SCROLL = 50;\n\n  constructor(\n    private activatedRoute: ActivatedRoute,\n    private alarmsViewService: AlarmsViewService,\n    private contextRouteService: ContextRouteService,\n    private router: Router\n  ) {\n    this.verifyIfFiltersMatchingAlarm();\n  }\n\n  /**\n   * Handles the change of the active route.\n   *\n   * @param isActive - A boolean indicating whether the route is active or not.\n   * @param scrollAnchor - The ListItemComponent used as a scroll anchor.\n   * @param alarm - The IAlarm object representing the active alarm.\n   */\n  activeRouteChanged(isActive: boolean, scrollAnchor: ListItemComponent, alarm: IAlarm): void {\n    if (isActive) {\n      scrollAnchor.element.nativeElement.scrollIntoViewIfNeeded\n        ? scrollAnchor.element.nativeElement.scrollIntoViewIfNeeded()\n        : scrollAnchor.element.nativeElement.scrollIntoView();\n      this.activeAlarm$.next(alarm);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.alarms && changes.alarms) {\n      this.activeAlarm$.next(null);\n      this.isEmptyListLoading = !this.alarms?.data?.length;\n      this.alarms.data = this.alarms.data.map((alarm: IAlarm) => {\n        alarm.link = this.getRouterLink(alarm);\n        return alarm;\n      });\n    }\n  }\n\n  ngAfterViewInit(): void {\n    if (this.alarmsViewService.isIntervalRefresh()) {\n      const scrollElement = this.innerScrollWrapper.nativeElement;\n      fromEvent(scrollElement, 'scroll')\n        .pipe(takeUntil(this.destroy$), debounceTime(300))\n        .subscribe((event: Event) => {\n          const target = event.target as HTMLElement;\n          this.isScrolling = this.shouldCountdownIntervalBeHidden(target);\n          this.onScrollingStateChange.emit(this.isScrolling);\n        });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  onAlarmOpen(alarm: IAlarm): void {\n    this.onSelectedAlarm.emit(alarm);\n  }\n\n  getRouterLink(alarm: IAlarm): string {\n    if (this.navigationOptions.alwaysNavigateToAllAlarms) {\n      return this.alarmsViewService.getRouterLink(null, alarm);\n    }\n    const contextData = this.contextRouteService.getContextData(this.activatedRoute);\n    return this.alarmsViewService.getRouterLink(contextData, alarm);\n  }\n\n  private shouldCountdownIntervalBeHidden(target: HTMLElement): boolean {\n    const scrollTopPixels = target.scrollTop;\n    return scrollTopPixels > this.HIDE_INTERVAL_COUNTDOWN_SCROLL;\n  }\n\n  private verifyIfFiltersMatchingAlarm() {\n    this.activeChildParam$ = this.router.events.pipe(\n      filter(e => e instanceof NavigationEnd && this.activatedRoute.children.length > 0),\n      switchMap(() => this.activatedRoute.children[0].params),\n      map(params => params.id),\n      distinctUntilChanged(),\n      shareReplay(),\n      takeUntil(this.destroy$)\n    );\n\n    // done to get the first navigation\n    this.activeChildParam$.subscribe();\n  }\n}\n","<div\n  class=\"inner-scroll\"\n  [ngClass]=\"{ 'split-view__list bg-level-1': splitView, 'bg-component': !splitView }\"\n  data-cy=\"c8y-alarms-list\"\n  #scrollWrapper\n>\n  <div\n    class=\"flex-wrap flex-no-shrink sticky-top m-b-16\"\n    [ngClass]=\"{\n      'separator-bottom card-header p-b-0': splitView,\n      'd-flex fit-w separator-top-bottom widget-bar p-l-16 p-r-16':\n        !splitView && navigationOptions.allowNavigationToAlarmsView\n    }\"\n  >\n    <div\n      class=\"h4 card-title\"\n      *ngIf=\"splitView\"\n    >\n      {{ 'Alarms list' | translate }}\n    </div>\n    <div\n      [ngClass]=\"{ 'fit-w d-flex a-i-center gap-16': !splitView, 'fit-h-20 m-l-auto': splitView }\"\n    >\n      <ng-content></ng-content>\n    </div>\n    <!--  Loading -->\n    <div\n      class=\"fit-w overflow-hidden\"\n      [ngClass]=\"{ 'p-t-16': splitView }\"\n    >\n      <div\n        class=\"loading-bar\"\n        style=\"z-index: 101\"\n        [ngClass]=\"{ active: isInitialLoading && !isEmptyListLoading }\"\n      ></div>\n    </div>\n\n    <div\n      class=\"alert alert-warning\"\n      role=\"alert\"\n      translate\n      *ngIf=\"\n        !isEmptyListLoading &&\n        (activeChildParam$ | async) &&\n        (activeAlarm$ | async)?.id !== (activeChildParam$ | async)\n      \"\n    >\n      The selected alarm is not currently in the list, please change your filter.\n    </div>\n  </div>\n  <c8y-list-group\n    class=\"p-r-16 interactive\"\n    [ngStyle]=\"{ opacity: isInitialLoading && !isEmptyListLoading ? 0.2 : 1 }\"\n    style=\"transition: opacity 0.15s linear\"\n    data-cy=\"c8y-alarm-list--group\"\n  >\n    <c8y-li-timeline\n      class=\"pointer\"\n      role=\"button\"\n      data-cy=\"c8y-alarm-list--timeline-repeat\"\n      *c8yFor=\"let alarm of alarms; let i = index; loadMore: loadMoreMode\"\n      [routerLink]=\"navigationOptions.allowNavigationToAlarmsView ? alarm.link : null\"\n      routerLinkActive=\"active\"\n      queryParamsHandling=\"merge\"\n      (isActiveChange)=\"activeRouteChanged($event, liScrollAnchor, alarm)\"\n      (click)=\"onAlarmOpen(alarm)\"\n      [queryParams]=\"navigationOptions.includeClearedQueryParams ? { showCleared: alarm.status === 'CLEARED' } : {}\"\n    >\n      {{ alarm.time | c8yDate: 'mediumDate' }}\n      {{ alarm.time | c8yDate: 'mediumTime' }}\n      <c8y-li #liScrollAnchor>\n        <c8y-li-icon class=\"a-s-start\">\n          <div class=\"alarm-icons\">\n            <c8y-alarms-icon [alarm]=\"alarm\"></c8y-alarms-icon>\n          </div>\n          <button\n            class=\"btn-clean text-center\"\n            [attr.aria-label]=\"\n              alarmBadgeTooltip\n                | translate\n                  : { alarmFirstOccurrenceTime: alarm.firstOccurrenceTime | c8yDate: 'medium' }\n            \"\n            [tooltip]=\"\n              alarmBadgeTooltip\n                | translate\n                  : { alarmFirstOccurrenceTime: alarm.firstOccurrenceTime | c8yDate: 'medium' }\n            \"\n            placement=\"right\"\n            container=\"body\"\n            type=\"button\"\n            *ngIf=\"alarm.firstOccurrenceTime\"\n            (click)=\"$event.stopPropagation()\"\n            [delay]=\"500\"\n          >\n            <span\n              class=\"badge badge-info\"\n              *ngIf=\"alarm.count > 1\"\n            >\n              {{ alarm.count }}\n            </span>\n          </button>\n        </c8y-li-icon>\n        <c8y-li-body class=\"a-s-stretch\">\n          <div class=\"d-flex a-i-start fit-h\">\n            <div class=\"min-width-0 flex-grow\">\n              <p class=\"text-truncate-wrap p-b-4\">\n                {{ alarm.text | translate }}\n              </p>\n              <div class=\"d-flex\">\n                <p class=\"small text-muted flex-grow\">\n                  <i [c8yIcon]=\"'exchange'\"></i>\n                  {{ alarm.source.name }}\n                </p>\n              </div>\n            </div>\n          </div>\n        </c8y-li-body>\n      </c8y-li>\n    </c8y-li-timeline>\n    <c8y-loading *ngIf=\"isInitialLoading && isEmptyListLoading\"></c8y-loading>\n    <div\n      class=\"p-relative p-l-24\"\n      *ngIf=\"isEmptyListLoading && !isInitialLoading\"\n    >\n      <c8y-ui-empty-state\n        [icon]=\"'c8y-alert-idle'\"\n        [title]=\"'No alarms to display.' | translate\"\n        data-cy=\"alarm-list--empty-state\"\n      >\n        <p c8y-guide-docs>\n          <small\n            translate\n            ngNonBindable\n          >\n            Find out more in the\n            <a\n              c8y-guide-href=\"/docs/device-management-application/monitoring-and-controlling-devices/#working-with-alarms\"\n            >\n              user documentation\n            </a>\n            .\n          </small>\n        </p>\n      </c8y-ui-empty-state>\n    </div>\n  </c8y-list-group>\n</div>\n"]}
|
package/esm2022/core/data-grid/column/expandable-row-column/expandable.cell-renderer.component.mjs
CHANGED
|
@@ -1,16 +1,17 @@
|
|
|
1
|
-
import { ChangeDetectorRef, Component, DestroyRef, inject } from '@angular/core';
|
|
1
|
+
import { ChangeDetectorRef, Component, DestroyRef, Inject, forwardRef, inject } from '@angular/core';
|
|
2
2
|
import { CellRendererContext } from '../cell-renderer';
|
|
3
3
|
import { DataGridComponent } from '../../data-grid.component';
|
|
4
4
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
5
5
|
import { gettext } from '../../../i18n/gettext';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "../cell-renderer";
|
|
8
|
-
import * as i2 from "
|
|
9
|
-
import * as i3 from "
|
|
10
|
-
import * as i4 from "../../../
|
|
11
|
-
import * as i5 from "
|
|
8
|
+
import * as i2 from "@angular/common";
|
|
9
|
+
import * as i3 from "../../../common/icon.directive";
|
|
10
|
+
import * as i4 from "../../../i18n/c8y-translate.pipe";
|
|
11
|
+
import * as i5 from "../../data-grid.component";
|
|
12
12
|
export class ExpandableCellRendererComponent {
|
|
13
|
-
constructor(context, dataGridComponent,
|
|
13
|
+
constructor(context, dataGridComponent, // forwardRef is needed because of circular dependency
|
|
14
|
+
cd) {
|
|
14
15
|
this.context = context;
|
|
15
16
|
this.dataGridComponent = dataGridComponent;
|
|
16
17
|
this.cd = cd;
|
|
@@ -37,7 +38,7 @@ export class ExpandableCellRendererComponent {
|
|
|
37
38
|
});
|
|
38
39
|
}
|
|
39
40
|
}
|
|
40
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: ExpandableCellRendererComponent, deps: [{ token: i1.CellRendererContext }, { token:
|
|
41
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: ExpandableCellRendererComponent, deps: [{ token: i1.CellRendererContext }, { token: forwardRef(() => DataGridComponent) }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
41
42
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.9", type: ExpandableCellRendererComponent, selector: "c8y-expandable-cell-renderer", ngImport: i0, template: `
|
|
42
43
|
<button
|
|
43
44
|
class="btn btn-dot collapse-btn"
|
|
@@ -51,7 +52,7 @@ export class ExpandableCellRendererComponent {
|
|
|
51
52
|
<i c8yIcon="chevron-right" *ngIf="!loading"></i>
|
|
52
53
|
<i class="icon-spin" c8yIcon="circle-o-notch" *ngIf="loading"></i>
|
|
53
54
|
</button>
|
|
54
|
-
`, isInline: true, dependencies: [{ kind: "directive", type:
|
|
55
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "pipe", type: i4.C8yTranslatePipe, name: "translate" }] }); }
|
|
55
56
|
}
|
|
56
57
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: ExpandableCellRendererComponent, decorators: [{
|
|
57
58
|
type: Component,
|
|
@@ -72,5 +73,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
72
73
|
`,
|
|
73
74
|
selector: 'c8y-expandable-cell-renderer'
|
|
74
75
|
}]
|
|
75
|
-
}], ctorParameters: () => [{ type: i1.CellRendererContext }, { type:
|
|
76
|
-
|
|
76
|
+
}], ctorParameters: () => [{ type: i1.CellRendererContext }, { type: i5.DataGridComponent, decorators: [{
|
|
77
|
+
type: Inject,
|
|
78
|
+
args: [forwardRef(() => DataGridComponent)]
|
|
79
|
+
}] }, { type: i0.ChangeDetectorRef }] });
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwYW5kYWJsZS5jZWxsLXJlbmRlcmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2NvcmUvZGF0YS1ncmlkL2NvbHVtbi9leHBhbmRhYmxlLXJvdy1jb2x1bW4vZXhwYW5kYWJsZS5jZWxsLXJlbmRlcmVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsTUFBTSxFQUNOLFVBQVUsRUFDVixNQUFNLEVBQ1AsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDaEUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHVCQUF1QixDQUFDOzs7Ozs7O0FBbUJoRCxNQUFNLE9BQU8sK0JBQStCO0lBTzFDLFlBQ1MsT0FBNEIsRUFDaUIsaUJBQW9DLEVBQUUsc0RBQXNEO0lBQ3hJLEVBQXFCO1FBRnRCLFlBQU8sR0FBUCxPQUFPLENBQXFCO1FBQ2lCLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7UUFDaEYsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFUdEIsYUFBUSxHQUFHLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUMvQixXQUFNLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3BDLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFDbkIsWUFBTyxHQUFHLEtBQUssQ0FBQztRQUNoQixlQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBTTdCLENBQUM7SUFFSixZQUFZO1FBQ1YsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ25ELElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO1FBQzFCLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7WUFDcEIsSUFBSSxDQUFDLGlCQUFpQjtpQkFDbkIsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDO2lCQUN6QixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2lCQUN6QyxTQUFTLENBQUMsQ0FBQyxVQUFtQixFQUFFLEVBQUU7Z0JBQ2pDLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO2dCQUNyQixJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztnQkFDN0IsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUMxQixDQUFDLENBQUMsQ0FBQztRQUNQLENBQUM7SUFDSCxDQUFDOzhHQTVCVSwrQkFBK0IscURBU2hDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztrR0FUbEMsK0JBQStCLG9FQWhCaEM7Ozs7Ozs7Ozs7Ozs7R0FhVDs7MkZBR1UsK0JBQStCO2tCQWpCM0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7R0FhVDtvQkFDRCxRQUFRLEVBQUUsOEJBQThCO2lCQUN6Qzs7MEJBVUksTUFBTTsyQkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgQ29tcG9uZW50LFxuICBEZXN0cm95UmVmLFxuICBJbmplY3QsXG4gIGZvcndhcmRSZWYsXG4gIGluamVjdFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENlbGxSZW5kZXJlckNvbnRleHQgfSBmcm9tICcuLi9jZWxsLXJlbmRlcmVyJztcbmltcG9ydCB7IERhdGFHcmlkQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vZGF0YS1ncmlkLmNvbXBvbmVudCc7XG5pbXBvcnQgeyB0YWtlVW50aWxEZXN0cm95ZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyBnZXR0ZXh0IH0gZnJvbSAnLi4vLi4vLi4vaTE4bi9nZXR0ZXh0JztcblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGJ1dHRvblxuICAgICAgY2xhc3M9XCJidG4gYnRuLWRvdCBjb2xsYXBzZS1idG5cIlxuICAgICAgdGl0bGU9XCJ7eyAoaXNFeHBhbmRlZCA/IGNvbGxhcHNlIDogZXhwYW5kKSB8IHRyYW5zbGF0ZSB9fVwiXG4gICAgICBbYXR0ci5hcmlhLWxhYmVsXT1cIihpc0V4cGFuZGVkID8gY29sbGFwc2UgOiBleHBhbmQpIHwgdHJhbnNsYXRlXCJcbiAgICAgIFthdHRyLmFyaWEtY29udHJvbHNdPVwiY29udGV4dC5pdGVtLmlkXCJcbiAgICAgIFthdHRyLmFyaWEtZXhwYW5kZWRdPVwiaXNFeHBhbmRlZFwiXG4gICAgICBbbmdDbGFzc109XCJ7IGFjdGl2ZTogaXNFeHBhbmRlZCB9XCJcbiAgICAgIChjbGljayk9XCJ0b2dnbGVFeHBhbmQoKVwiXG4gICAgPlxuICAgICAgPGkgYzh5SWNvbj1cImNoZXZyb24tcmlnaHRcIiAqbmdJZj1cIiFsb2FkaW5nXCI+PC9pPlxuICAgICAgPGkgY2xhc3M9XCJpY29uLXNwaW5cIiBjOHlJY29uPVwiY2lyY2xlLW8tbm90Y2hcIiAqbmdJZj1cImxvYWRpbmdcIj48L2k+XG4gICAgPC9idXR0b24+XG4gIGAsXG4gIHNlbGVjdG9yOiAnYzh5LWV4cGFuZGFibGUtY2VsbC1yZW5kZXJlcidcbn0pXG5leHBvcnQgY2xhc3MgRXhwYW5kYWJsZUNlbGxSZW5kZXJlckNvbXBvbmVudCB7XG4gIHJlYWRvbmx5IGNvbGxhcHNlID0gZ2V0dGV4dCgnQ29sbGFwc2UnKTtcbiAgcmVhZG9ubHkgZXhwYW5kID0gZ2V0dGV4dCgnRXhwYW5kJyk7XG4gIGlzRXhwYW5kZWQgPSBmYWxzZTtcbiAgbG9hZGluZyA9IGZhbHNlO1xuICBkZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBjb250ZXh0OiBDZWxsUmVuZGVyZXJDb250ZXh0LFxuICAgIEBJbmplY3QoZm9yd2FyZFJlZigoKSA9PiBEYXRhR3JpZENvbXBvbmVudCkpIHB1YmxpYyBkYXRhR3JpZENvbXBvbmVudDogRGF0YUdyaWRDb21wb25lbnQsIC8vIGZvcndhcmRSZWYgaXMgbmVlZGVkIGJlY2F1c2Ugb2YgY2lyY3VsYXIgZGVwZW5kZW5jeVxuICAgIHByaXZhdGUgY2Q6IENoYW5nZURldGVjdG9yUmVmXG4gICkge31cblxuICB0b2dnbGVFeHBhbmQoKSB7XG4gICAgaWYgKHRoaXMuaXNFeHBhbmRlZCkge1xuICAgICAgdGhpcy5kYXRhR3JpZENvbXBvbmVudC5jb2xsYXBzZSh0aGlzLmNvbnRleHQuaXRlbSk7XG4gICAgICB0aGlzLmlzRXhwYW5kZWQgPSBmYWxzZTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5sb2FkaW5nID0gdHJ1ZTtcbiAgICAgIHRoaXMuZGF0YUdyaWRDb21wb25lbnRcbiAgICAgICAgLmV4cGFuZCh0aGlzLmNvbnRleHQuaXRlbSlcbiAgICAgICAgLnBpcGUodGFrZVVudGlsRGVzdHJveWVkKHRoaXMuZGVzdHJveVJlZikpXG4gICAgICAgIC5zdWJzY3JpYmUoKGlzRXhwYW5kZWQ6IGJvb2xlYW4pID0+IHtcbiAgICAgICAgICB0aGlzLmxvYWRpbmcgPSBmYWxzZTtcbiAgICAgICAgICB0aGlzLmlzRXhwYW5kZWQgPSBpc0V4cGFuZGVkO1xuICAgICAgICAgIHRoaXMuY2QuZGV0ZWN0Q2hhbmdlcygpO1xuICAgICAgICB9KTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -8,10 +8,9 @@ export function loadLocale(moduleLang) {
|
|
|
8
8
|
resolve(cache.get(moduleLang));
|
|
9
9
|
}
|
|
10
10
|
try {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
`node_modules/@angular/common/locales/${moduleLang}.mjs`).then(module => {
|
|
11
|
+
// Loading @angular/common dynamically aliased to angular.common.
|
|
12
|
+
// Check packages/devkit/src/webpack/config/base.ts for more information.
|
|
13
|
+
import(`angular-common/locales/${moduleLang}.mjs`).then(module => {
|
|
15
14
|
cache.set(moduleLang, module);
|
|
16
15
|
resolve(module);
|
|
17
16
|
});
|
|
@@ -21,4 +20,4 @@ export function loadLocale(moduleLang) {
|
|
|
21
20
|
}
|
|
22
21
|
});
|
|
23
22
|
}
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC1sb2NhbGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9jb3JlL2kxOG4vbG9hZC1sb2NhbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxLQUFLLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztBQUN4Qjs7R0FFRztBQUNILE1BQU0sVUFBVSxVQUFVLENBQUMsVUFBa0I7SUFDM0MsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUNyQyxJQUFJLEtBQUssQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztZQUMxQixPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQ2pDLENBQUM7UUFFRCxJQUFJLENBQUM7WUFDSCxpRUFBaUU7WUFDakUseUVBQXlFO1lBQ3pFLE1BQU0sQ0FBQywwQkFBMEIsVUFBVSxNQUFNLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUU7Z0JBQy9ELEtBQUssQ0FBQyxHQUFHLENBQUMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxDQUFDO2dCQUM5QixPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDbEIsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztZQUNmLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNoQixDQUFDO0lBQ0gsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgY2FjaGUgPSBuZXcgTWFwKCk7XG4vKipcbiAqIEBpZ25vcmVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGxvYWRMb2NhbGUobW9kdWxlTGFuZzogc3RyaW5nKSB7XG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgaWYgKGNhY2hlLmhhcyhtb2R1bGVMYW5nKSkge1xuICAgICAgcmVzb2x2ZShjYWNoZS5nZXQobW9kdWxlTGFuZykpO1xuICAgIH1cblxuICAgIHRyeSB7XG4gICAgICAvLyBMb2FkaW5nIEBhbmd1bGFyL2NvbW1vbiBkeW5hbWljYWxseSBhbGlhc2VkIHRvIGFuZ3VsYXIuY29tbW9uLlxuICAgICAgLy8gQ2hlY2sgcGFja2FnZXMvZGV2a2l0L3NyYy93ZWJwYWNrL2NvbmZpZy9iYXNlLnRzIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuICAgICAgaW1wb3J0KGBhbmd1bGFyLWNvbW1vbi9sb2NhbGVzLyR7bW9kdWxlTGFuZ30ubWpzYCkudGhlbihtb2R1bGUgPT4ge1xuICAgICAgICBjYWNoZS5zZXQobW9kdWxlTGFuZywgbW9kdWxlKTtcbiAgICAgICAgcmVzb2x2ZShtb2R1bGUpO1xuICAgICAgfSk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIHJlamVjdChlcnJvcik7XG4gICAgfVxuICB9KTtcbn1cbiJdfQ==
|
|
@@ -1397,9 +1397,8 @@ class AlarmsListComponent {
|
|
|
1397
1397
|
*/
|
|
1398
1398
|
activeRouteChanged(isActive, scrollAnchor, alarm) {
|
|
1399
1399
|
if (isActive) {
|
|
1400
|
-
|
|
1401
|
-
|
|
1402
|
-
? scrollIntoViewIfNeeded()
|
|
1400
|
+
scrollAnchor.element.nativeElement.scrollIntoViewIfNeeded
|
|
1401
|
+
? scrollAnchor.element.nativeElement.scrollIntoViewIfNeeded()
|
|
1403
1402
|
: scrollAnchor.element.nativeElement.scrollIntoView();
|
|
1404
1403
|
this.activeAlarm$.next(alarm);
|
|
1405
1404
|
}
|