All files / src/components/web-component-wrapper si-web-component-editor-wrapper.component.ts

18.51% Statements 5/27
33.33% Branches 6/18
12.5% Functions 1/8
8.69% Lines 2/23

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

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75          3x                             3x                                                                                                            
/**
 * Copyright (c) Siemens 2016 - 2026
 * SPDX-License-Identifier: MIT
 */
import { AfterViewInit, Component, OnDestroy } from '@angular/core';
import { Subject } from 'rxjs';
 
import {
  WidgetConfig,
  WidgetConfigStatus,
  WidgetInstanceEditor,
  WidgetInstanceEditorWizard,
  WidgetInstanceEditorWizardState
} from '../../model/widgets.model';
import { SiWebComponentWrapperBaseComponent } from './si-web-component-wrapper-base.component';
 
@Component({
  selector: 'si-web-component-editor-wrapper',
  templateUrl: './si-web-component-wrapper.component.html'
})
export class SiWebComponentEditorWrapperComponent
  extends SiWebComponentWrapperBaseComponent<WidgetInstanceEditor>
  implements WidgetInstanceEditor, WidgetInstanceEditorWizard, AfterViewInit, OnDestroy
{
  state!: WidgetInstanceEditorWizardState;
  stateChange = new Subject<WidgetInstanceEditorWizardState>();
  configChange = new Subject<WidgetConfig | Omit<WidgetConfig, 'id'>>();
 
  /**
   * This will be set when setupWidgetInstanceEditor is executed
   */
  statusChangesHandler?: (statusChanges: Partial<WidgetConfigStatus>) => void;
 
  private webComponentEventListener = (event: CustomEventInit<WidgetConfig>): void =>
    event.detail && this.configChange.next(event.detail);
 
  private webComponentStateChangeListener = (
    event: CustomEventInit<WidgetInstanceEditorWizardState>
  ): void => {
    if (event.detail) {
      this.state = event.detail;
      this.stateChange.next(event.detail);
    }
  };
  private webComponentStatusChangesListener = (
    event: CustomEventInit<Partial<WidgetConfigStatus>>
  ): void => {
    if (event.detail) {
      this.statusChangesHandler?.(event.detail);
    }
  };
 
  override ngAfterViewInit(): void {
    super.ngAfterViewInit();
    this.webComponent?.addEventListener('stateChange', this.webComponentStateChangeListener);
    this.webComponent?.addEventListener('statusChanges', this.webComponentStatusChangesListener);
    this.webComponent?.addEventListener('configChange', this.webComponentEventListener);
    this.webComponentHost().nativeElement.appendChild(this.webComponent);
  }
 
  ngOnDestroy(): void {
    this.webComponent?.removeEventListener('stateChange', this.webComponentStateChangeListener);
    this.webComponent?.removeEventListener('statusChanges', this.webComponentStatusChangesListener);
    this.webComponent?.removeEventListener('configChange', this.webComponentEventListener);
  }
 
  next(): void {
    this.webComponent?.dispatchEvent(new CustomEvent('next'));
  }
 
  previous(): void {
    this.webComponent?.dispatchEvent(new CustomEvent('previous'));
  }
}