@smartbit4all/ng-client 4.3.17 → 4.3.19

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.
@@ -100,7 +100,9 @@ export class SmartformwidgetComponent {
100
100
  });
101
101
  this.onBlur?.pipe(takeUntil(this._destroy$)).subscribe(() => {
102
102
  this.getErrorMessage(this.widgetInstance);
103
- this.getControlMessages(this.widgetInstance.key);
103
+ if (this.compLib === this.componentLibrary.PRIMENG) {
104
+ this.getControlMessages(this.widgetInstance.key);
105
+ }
104
106
  });
105
107
  // handle initial error message from server
106
108
  this.getErrorMessage(this.widgetInstance);
@@ -1033,4 +1035,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
1033
1035
  type: ViewChild,
1034
1036
  args: ['timeInput']
1035
1037
  }] } });
1036
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartformwidget.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/smartformwidget/smartformwidget.component.ts","../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/smartformwidget/smartformwidget.component.html"],"names":[],"mappings":"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","sourcesContent":["import { COMMA, ENTER } from '@angular/cdk/keycodes';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { UntypedFormControl, UntypedFormGroup, ValidatorFn, Validators } from '@angular/forms';\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatChipInputEvent } from '@angular/material/chips';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { deepEqual } from 'fast-equals';\nimport moment from 'moment';\nimport { ContentChange, QuillEditorComponent, QuillModules } from 'ngx-quill';\nimport { EditorTextChangeEvent } from 'primeng/editor';\nimport { Observable, Subject, distinctUntilChanged, map, startWith, takeUntil } from 'rxjs';\nimport { ComponentFactoryService } from '../../../component-factory-service/projects';\nimport {\n  IconPosition,\n  UiAction,\n  UiActionButtonType,\n  UiActionDescriptor,\n  UiActionUploadDescriptor,\n} from '../../../view-context/api';\nimport { UiActionToolbarComponent } from '../../../view-context/smart-ui-action/ui-action-toolbar.component';\nimport {\n  COMPONENT_LIBRARY,\n  ComponentLibrary,\n} from '../../../view-context/utility/componentLibrary';\nimport { SmartStyleUtility } from '../../../view-context/utility/smart-style-utility';\nimport {\n  SmartFormWidgetDirection,\n  SmartFormWidgetType,\n  SmartWidgetHintPositionEnum,\n} from '../../api/model/models';\nimport { SmartFormService } from '../../services/smartform.service';\nimport {\n  SmartButton,\n  SmartFormWidget,\n  SmartItem,\n  SmartItems,\n  SmartMatrix,\n} from '../../smartform.form-model';\nimport {\n  SmartFormTextFieldButtonIconPosition,\n  SmartValidator,\n  SophisticatedValueChange,\n  Value,\n} from '../../smartform.model';\nimport { SmartFileEditorComponent } from '../components/smart-file-editor/smart-file-editor.component';\nimport { SmartMultiFileEditorComponent } from '../components/smart-multi-file-editor/smart-multi-file-editor.component';\nimport { Message } from 'primeng/api';\nexport class SmartWidgetSettings {\n  public static useUtc = false;\n}\n@Component({\n  selector: 'smartformwidget',\n  templateUrl: './smartformwidget.component.html',\n  styleUrls: ['./smartformwidget.component.css'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SmartformwidgetComponent implements OnInit, OnDestroy, AfterViewInit {\n  private _destroy$: Subject<void> = new Subject();\n\n  hidePassword: boolean = true;\n\n  smartComponent: any;\n\n  errorMessages: Message[] = [];\n\n  @Input() form!: UntypedFormGroup;\n  @Input() widgetInstance!: SmartFormWidget<any>;\n  @Input() onBlur?: Subject<any>;\n  @Input() onValueChange?: Subject<any>;\n  @Input() labelColor?: string;\n  @Input() sophisticatedValueChange!: Subject<SophisticatedValueChange>;\n  @Input() blurSophisticatedValueChange!: Subject<SophisticatedValueChange>;\n\n  @Output() valueCleared = new EventEmitter<{\n    event?: any;\n    key: any;\n  }>();\n\n  smartFormWidgetType = SmartFormWidgetType;\n\n  capsOn: any;\n\n  @ViewChild('chipInput') chipInputChild?: ElementRef<HTMLInputElement>;\n\n  filteredValueList?: Observable<string[] | undefined>;\n\n  hasError: boolean = false;\n  errorKey?: string;\n\n  indicatorItems?: any[];\n  defaultDate?: Date;\n  // customComponent\n  @ViewChild('customComponent', { read: ViewContainerRef })\n  customComponentVcRef?: ViewContainerRef;\n  customComponentRef?: ComponentRef<any>;\n\n  filteredOptions?: Observable<SmartItem<any>[]>;\n  toHighlight: string = '';\n\n  @ViewChild('quillEditor') quill?: QuillEditorComponent;\n\n  isEnterPressed: boolean = false;\n\n  isDatePickerRequired: boolean = false;\n\n  SmartWidgetHintPosition = SmartWidgetHintPositionEnum;\n\n  // toolbar\n  @ViewChild('toolbar') toolbar?: UiActionToolbarComponent;\n\n  @ViewChildren(SmartformwidgetComponent)\n  childrenWidgetsQL?: QueryList<SmartformwidgetComponent>;\n  componentLibrary = ComponentLibrary;\n  emptyQuillToolbar: QuillModules = {\n    toolbar: false,\n  };\n\n  @ViewChild('sb4Textarea') sb4Textarea!: ElementRef<HTMLTextAreaElement>;\n  @ViewChild(SmartFileEditorComponent) fileUploader!: SmartFileEditorComponent;\n  @ViewChild(SmartMultiFileEditorComponent) multiFileUploader?: SmartMultiFileEditorComponent;\n\n  constructor(\n    private service: SmartFormService,\n    private cfService: ComponentFactoryService,\n    private sanitizer: DomSanitizer,\n    @Inject(COMPONENT_LIBRARY) public compLib: ComponentLibrary,\n    public changeDetector: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.CONTAINER &&\n      this.widgetInstance.valueList\n    ) {\n      this.widgetInstance.valueList = this.service.filterWidgetsByVisibility(\n        this.widgetInstance.valueList\n      );\n    }\n    this.form.valueChanges.pipe(takeUntil(this._destroy$)).subscribe(() => {\n      this.getErrorMessage(this.widgetInstance);\n    });\n    this.onBlur?.pipe(takeUntil(this._destroy$)).subscribe(() => {\n      this.getErrorMessage(this.widgetInstance);\n      this.getControlMessages(this.widgetInstance.key!);\n    });\n    // handle initial error message from server\n    this.getErrorMessage(this.widgetInstance);\n    // this.getControlMessages(this.widgetInstance.key!);\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.INDICATOR &&\n      this.widgetInstance.indicator\n    ) {\n      if (this.widgetInstance.indicator?.indicatorLength) {\n        this.indicatorItems = new Array<any>(this.widgetInstance.indicator.indicatorLength);\n      }\n      this.form.controls[this.widgetInstance.indicator!.indicateProperty].valueChanges\n        .pipe(takeUntil(this._destroy$))\n        .subscribe((value: any) => {\n          if (this.widgetInstance.type === SmartFormWidgetType.INDICATOR) {\n            this.widgetInstance.indicator!.indicatorValue =\n              this.widgetInstance.indicator!.changeIndicatorStatus(value);\n          }\n        });\n    }\n\n    if (this.widgetInstance.type === SmartFormWidgetType.DATE_PICKER) {\n      if (this.widgetInstance.value) {\n        this.defaultDate = new Date(this.widgetInstance.value);\n      }\n    }\n\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_FIELD &&\n      this.widgetInstance.selection\n    ) {\n      this.filteredOptions = this.onValueChange!.pipe(\n        startWith(''),\n        map((value) => this._filter(value || '')),\n        takeUntil(this._destroy$)\n      );\n    }\n\n    if (this.widgetInstance.type === SmartFormWidgetType.YOUTUBE_PLAYER) {\n      let videoId = this.parseYoutubeUrl(this.widgetInstance.link!);\n      if (videoId) this.widgetInstance.videoId = videoId;\n      const tag = document.createElement('script');\n\n      tag.src = 'https://www.youtube.com/iframe_api';\n      document.body.appendChild(tag);\n    }\n\n    let formControls: string[] = Object.keys(this.form.controls).filter(\n      (key: string) =>\n        key === this.widgetInstance.key || key.startsWith(`${this.widgetInstance.key}.`)\n    );\n\n    formControls.map((key: string) => {\n      this.form.controls[key].valueChanges\n        .pipe(distinctUntilChanged(), takeUntil(this._destroy$))\n        .subscribe((value: string) => {\n          if (\n            this.widgetInstance.type !== SmartFormWidgetType.TEXT_FIELD_CHIPS &&\n            this.widgetInstance.type !== SmartFormWidgetType.TEXT_FIELD_LOOKUP\n          ) {\n            const valueChange: SophisticatedValueChange = {\n              key,\n              value,\n              kind: this.getSophisticatedEventKind(),\n            };\n\n            this.sophisticatedValueChange.next(valueChange);\n          }\n        });\n    });\n  }\n\n  private getSophisticatedEventKind(): 'selection' | 'basic' {\n    return this.widgetInstance.type === SmartFormWidgetType.SELECT ||\n      this.widgetInstance.type === SmartFormWidgetType.SELECT_MULTIPLE ||\n      this.widgetInstance.type === SmartFormWidgetType.RADIO_BUTTON\n      ? 'selection'\n      : 'basic';\n  }\n\n  parseYoutubeUrl(url: string) {\n    url.replace('/shorts/', '/watch?v=');\n\n    var regExp = /^.*((youtu.be\\/)|(v\\/)|(\\/u\\/\\w\\/)|(embed\\/)|(watch\\?))\\??v?=?([^#&?]*).*/;\n    var match = url.match(regExp);\n\n    return match && match[7].length == 11 ? match[7] : false;\n  }\n\n  _hasJustChanged: boolean = false;\n\n  get hasJustChanged(): boolean {\n    return this._hasJustChanged;\n  }\n  set hasJustChanged(hasJustChanged: boolean) {\n    this._hasJustChanged = hasJustChanged;\n    new Promise((resolve) => setTimeout(resolve, 250)).then(() => {\n      this._hasJustChanged = false;\n    });\n  }\n\n  hasCreated: boolean = false;\n\n  @ViewChild('dateInput') dateInputChild?: ElementRef;\n  @ViewChild('timeInput') timeInputChild?: ElementRef;\n\n  onDatePickerBlur(event: any): void {\n    event.stopPropagation();\n\n    this.handleBlurEvent(this.widgetInstance);\n    this.handleDateChanged(this.form.controls[this.widgetInstance.key!].value);\n  }\n\n  onTimePickerBlur(event: any): void {\n    event.stopPropagation();\n\n    this.handleBlurEvent(this.widgetInstance);\n    this.handleTimeChanged(this.form.controls[`${this.widgetInstance.key}-time`].value);\n  }\n\n  ngAfterViewInit(): void {\n    if (this.widgetInstance.type === SmartFormWidgetType.COMPONENT) {\n      this.customComponentRef = this.cfService.createComponent(\n        this.customComponentVcRef!,\n        this.widgetInstance.component,\n        this.widgetInstance.input\n      );\n    }\n    if (this.compLib === this.componentLibrary.MATERIAL) {\n      if (\n        this.widgetInstance.type === SmartFormWidgetType.DATE_TIME_PICKER ||\n        this.widgetInstance.type === SmartFormWidgetType.MONTH_PICKER\n      ) {\n        this.isDatePickerRequired = !!this.widgetInstance.validators?.some(\n          (smartValidator: SmartValidator) => smartValidator.validator === Validators.required\n        );\n\n        let time;\n        if (this.widgetInstance.value) {\n          let date = new Date(this.widgetInstance.value);\n          let hour = SmartWidgetSettings.useUtc ? date.getUTCHours() : date.getHours();\n          let min = SmartWidgetSettings.useUtc ? date.getUTCMinutes() : date.getMinutes();\n          time = String(hour).padStart(2, '0') + ':' + String(min).padStart(2, '0');\n          this.widgetInstance.value = moment(date);\n          const dateFormControl = this.form.controls[this.widgetInstance.key];\n          if (dateFormControl) {\n            dateFormControl.setValue(this.widgetInstance.value);\n          }\n        } else {\n          time = '';\n        }\n\n        let validators: ValidatorFn[] = [];\n        if (this.widgetInstance.validators) {\n          validators = this.widgetInstance.validators?.map((validator: SmartValidator) => {\n            return validator.validator;\n          });\n        }\n\n        const timeFormControl = new UntypedFormControl(time, validators);\n\n        if (this.widgetInstance.isDisabled) {\n          timeFormControl.disable();\n        }\n\n        this.form.addControl(`${this.widgetInstance.key}-time`, timeFormControl);\n\n        this.hasCreated = true;\n\n        this.form.controls[this.widgetInstance.key!].valueChanges\n          .pipe(takeUntil(this._destroy$))\n          .subscribe((_moment: any) => {\n            this.handleDateChanged(_moment);\n          });\n        this.form.controls[`${this.widgetInstance.key}-time`].valueChanges\n          .pipe(takeUntil(this._destroy$))\n          .subscribe((timeValue: string) => {\n            this.handleTimeChanged(timeValue);\n          });\n      }\n    } else {\n      if (this.widgetInstance.type === SmartFormWidgetType.DATE_PICKER) {\n        this.form.controls[this.widgetInstance.key].valueChanges\n          .pipe(takeUntil(this._destroy$))\n          .subscribe((timeValue: string) => {\n            if (timeValue) {\n              this.defaultDate = new Date(timeValue);\n            } else {\n              this.defaultDate = undefined;\n            }\n          });\n      }\n    }\n\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_BOX &&\n      this.compLib === this.componentLibrary.PRIMENG &&\n      this.widgetInstance.textBoxProperties?.maxRows &&\n      this.sb4Textarea\n    ) {\n      var textarea = this.sb4Textarea.nativeElement;\n      var style = getComputedStyle(textarea);\n\n      var maxLines = this.widgetInstance.textBoxProperties.maxRows;\n      var lineHeight = parseInt(style.getPropertyValue('--sb4-textarea-line-height')) || 20;\n\n      var paddingTop = parseFloat(style.paddingTop) || 0;\n      var paddingBottom = parseFloat(style.paddingBottom) || 0;\n\n      var verticalExtras = paddingTop + paddingBottom;\n\n      textarea.style.height = 'auto';\n      textarea.style.maxHeight = `${lineHeight * maxLines + verticalExtras}px`;\n    }\n\n    if (this.widgetInstance.type === SmartFormWidgetType.FILE_UPLOADER && this.fileUploader) {\n      this.toolbar = this.fileUploader.toolbar;\n    }\n\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n      this.multiFileUploader\n    ) {\n      this.toolbar = this.multiFileUploader.toolbar;\n    }\n  }\n\n  handleDateChanged(_moment: any): void {\n    const isDateFocused = document.activeElement === this.dateInputChild?.nativeElement;\n    const isTimeFocused = document.activeElement === this.timeInputChild?.nativeElement;\n    const dateFormControl = this.form.controls[this.widgetInstance.key!];\n    const timeFormControl = this.form.controls[`${this.widgetInstance.key}-time`];\n\n    if (\n      !this.isDatePickerRequired &&\n      timeFormControl.hasValidator(Validators.required) &&\n      !_moment\n    ) {\n      timeFormControl.removeValidators(Validators.required);\n      timeFormControl.setValue('');\n    } else if (\n      !this.isDatePickerRequired &&\n      !timeFormControl.hasValidator(Validators.required) &&\n      _moment\n    ) {\n      timeFormControl.addValidators(Validators.required);\n\n      if (timeFormControl.value === '') {\n        const now = new Date();\n        timeFormControl.setValue(now.getHours() + ':' + now.getMinutes());\n        timeFormControl.markAsUntouched();\n      }\n    }\n\n    if (!_moment || isDateFocused || isTimeFocused) {\n      return;\n    }\n\n    if (this.hasJustChanged) {\n      this.hasJustChanged = false;\n      return;\n    }\n\n    const timeValue = timeFormControl.value || '00:00';\n    this.hasJustChanged = true;\n\n    if (this.widgetInstance.type === SmartFormWidgetType.DATE_TIME_PICKER) {\n      this.setDateFormControl(dateFormControl, _moment, timeValue);\n      this.widgetInstance.value = dateFormControl.value;\n    }\n  }\n\n  handleTimeChanged(timeValue: string): void {\n    const isFocused = document.activeElement === this.timeInputChild?.nativeElement;\n    const dateFormControl = this.form.controls[this.widgetInstance.key!];\n    const timeFormControl = this.form.controls[`${this.widgetInstance.key}-time`];\n\n    if (\n      !this.isDatePickerRequired &&\n      dateFormControl.hasValidator(Validators.required) &&\n      !timeValue\n    ) {\n      dateFormControl.removeValidators(Validators.required);\n      dateFormControl.setValue(dateFormControl.value ?? '');\n    } else if (\n      !this.isDatePickerRequired &&\n      !dateFormControl.hasValidator(Validators.required) &&\n      timeValue\n    ) {\n      dateFormControl.setValidators(Validators.required);\n    }\n\n    if (isFocused) {\n      return;\n    }\n\n    if (this.hasJustChanged) {\n      this.hasJustChanged = false;\n      return;\n    }\n\n    if (!timeValue) {\n      if (timeFormControl.hasValidator(Validators.required)) {\n        timeFormControl.markAsDirty();\n      }\n      return;\n    }\n\n    let _moment = dateFormControl.value;\n\n    if (!_moment) {\n      return;\n    }\n\n    this.hasJustChanged = true;\n    if (this.widgetInstance.type === SmartFormWidgetType.DATE_TIME_PICKER) {\n      this.setDateFormControl(dateFormControl, _moment, timeValue);\n    }\n  }\n\n  private setDateFormControl(dateFormControl: any, _moment: any, timeValue: string) {\n    if (_moment) {\n      let hour = timeValue.substring(0, 2);\n      let min = timeValue.substring(3, 5);\n      _moment.hour(hour);\n      _moment.minute(min);\n      dateFormControl.setValue(_moment);\n    }\n  }\n\n  getTime(): string {\n    if (this.widgetInstance.type === SmartFormWidgetType.DATE_TIME_PICKER) {\n      return this.widgetInstance.value.toISOString().split('T')[1].substring(0, 5);\n    }\n    return '';\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  onKeydown(): void {\n    this.isEnterPressed = true;\n\n    new Promise((resolve) => setTimeout(resolve, 500)).then(() => {\n      this.isEnterPressed = false;\n    });\n  }\n\n  togglePasswordVisibility(event: any): void {\n    if (!this.isEnterPressed) {\n      this.hidePassword = !this.hidePassword;\n    }\n  }\n\n  getNgClass(): { [className: string]: boolean } {\n    return SmartStyleUtility.getNgClasses(this.widgetInstance.style);\n  }\n\n  getStyle(): { [key: string]: string | number } {\n    if (!this.widgetInstance.style) {\n      this.widgetInstance.style = {\n        classesToAdd: [],\n        classesToRemove: [],\n        style: {},\n      };\n    }\n\n    if (!('width' in this.widgetInstance.style.style) && 'minWidth' in this.widgetInstance) {\n      this.widgetInstance.style.style['width'] = `${this.widgetInstance.minWidth}px`;\n    }\n    return SmartStyleUtility.getNgStyles(this.widgetInstance.style);\n  }\n\n  getLabelNgClass(): { [className: string]: boolean } {\n    if ('labelStyle' in this.widgetInstance) {\n      return SmartStyleUtility.getNgClasses(this.widgetInstance.labelStyle);\n    }\n\n    return {};\n  }\n\n  getLabelStyle(): { [key: string]: string | number } {\n    if ('labelStyle' in this.widgetInstance) {\n      return SmartStyleUtility.getNgStyles(this.widgetInstance.labelStyle);\n    }\n\n    return {};\n  }\n\n  /**\n   * Change handler for the potentially present Quill editor, enforcing max length limits if\n   * necessary.\n   *\n   * @param change the {@link ContentChange} the Quill editor emits\n   * @returns {@code void}\n   */\n  onRichTextEditorContentChanged(change: ContentChange): void {\n    if (this.widgetInstance.type !== SmartFormWidgetType.RICH_TEXT) {\n      return;\n    }\n\n    if (!this.widgetInstance.maxLength) {\n      return;\n    }\n\n    // we are permitted a number one greater than the requested: The quill editor contains an\n    // unremovable new-line character at the end of its content.\n    const maxLength: number = this.widgetInstance.maxLength + 1;\n    if (change.text.length <= maxLength) {\n      return;\n    }\n\n    const insertOpCount: number = change.delta.ops?.filter((it) => !!it.insert).length ?? 0;\n    if (insertOpCount > 0) {\n      this.quill?.quillEditor.setContents(change.oldDelta, 'silent');\n    }\n  }\n\n  onPrimeRichTextEditorContentChanged(change: EditorTextChangeEvent): void {\n    if (this.widgetInstance.type !== SmartFormWidgetType.RICH_TEXT) {\n      return;\n    }\n\n    if (!this.widgetInstance.maxLength) {\n      return;\n    }\n    // we are permitted a number one greater than the requested: The quill editor contains an\n    // unremovable new-line character at the end of its content.\n    const maxLength: number = this.widgetInstance.maxLength + 1;\n    if (change.textValue.length <= maxLength) {\n      return;\n    }\n  }\n\n  /**\n   * Calculates the number of remaining user-space characters allowed to be entered into the Quill\n   * editor.\n   *\n   * <p>\n   * The real length of the editor's content may be much longer - as it is persisted as an HTML\n   * document fragment behind the scenes. This method is concerned by the number of characters the\n   * user perceives.\n   *\n   * @returns the {@link number} of remaining permitted characters the user may input, or {@code -1}\n   *          if the leeway is not interpreted in the component's current state\n   */\n  getRichTextEditorLengthLeeway(): number {\n    if (this.widgetInstance.type !== SmartFormWidgetType.RICH_TEXT) {\n      return -1;\n    }\n\n    if (!this.widgetInstance.maxLength) {\n      return -1;\n    }\n\n    // we are permitted a number one greater than the requested: The quill editor contains an\n    // unremovable new-line character at the end of its content.\n    const maxLength: number = this.widgetInstance.maxLength + 1;\n    if (this.quill) {\n      // this is the intended path (user input):\n      return maxLength - this.quill.quillEditor.getText().length;\n    }\n\n    // fallback to the raw HTML content:\n    return maxLength - this.form.controls[this.widgetInstance.key].value.length;\n  }\n\n  addOnBlur = true;\n  readonly separatorKeysCodes = [ENTER, COMMA] as const;\n  readonly emptySeparatorKeysCodes = [] as const;\n\n  add(event: MatChipInputEvent): void {\n    if (this.widgetInstance.type !== SmartFormWidgetType.TEXT_FIELD_CHIPS) {\n      return;\n    }\n\n    const value = (event.value || '').trim();\n    if (this.setTextFieldChipsValue(value)) {\n      const valueChange: SophisticatedValueChange = {\n        key: this.widgetInstance.key,\n        value: this.form.controls[this.widgetInstance.key].value,\n        kind: 'selection',\n      };\n      this.sophisticatedValueChange.next(valueChange);\n    }\n    // Clear the input value\n    event.chipInput!.clear();\n    this.form.controls[this.widgetInstance.key].markAsTouched();\n  }\n\n  remove(value: SmartFormWidget<any>): void {\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_FIELD_CHIPS ||\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_FIELD_LOOKUP\n    ) {\n      const index = this.form.controls[this.widgetInstance.key].value.indexOf(value);\n\n      if (index >= 0) {\n        this.form.controls[this.widgetInstance.key].value.splice(index, 1);\n        this.form.controls[this.widgetInstance.key].updateValueAndValidity();\n        const valueChange: SophisticatedValueChange = {\n          key: this.widgetInstance.key,\n          value: this.form.controls[this.widgetInstance.key].value,\n          kind: 'selection',\n        };\n        this.sophisticatedValueChange.next(valueChange);\n      }\n    }\n  }\n\n  selected(event: MatAutocompleteSelectedEvent, widgetInstance: SmartFormWidget<any>): void {\n    let value = event.option.viewValue;\n    if (this.setTextFieldChipsValue(value)) {\n      if (\n        widgetInstance.type === SmartFormWidgetType.TEXT_FIELD_CHIPS ||\n        widgetInstance.type === SmartFormWidgetType.TEXT_FIELD_LOOKUP\n      ) {\n        const valueChange: SophisticatedValueChange = {\n          key: widgetInstance.key,\n          value: this.form.controls[widgetInstance.key].value,\n          kind: 'selection',\n        };\n        this.sophisticatedValueChange.next(valueChange);\n      }\n    }\n  }\n\n  private setTextFieldChipsValue(value: string): boolean {\n    if (this.widgetInstance.type !== SmartFormWidgetType.TEXT_FIELD_CHIPS) {\n      return false;\n    }\n\n    if (value) {\n      if (\n        (this.widgetInstance.maxValues &&\n          this.widgetInstance.value!.length < this.widgetInstance.maxValues) ||\n        !this.widgetInstance.maxValues\n      ) {\n        if (!this.form.controls[this.widgetInstance.key].value) {\n          let values = new Array<Object>();\n          this.widgetInstance.value = values;\n          this.form.controls[this.widgetInstance.key].setValue(values);\n          this.form.controls[this.widgetInstance.key].updateValueAndValidity();\n        }\n        this.form.controls[this.widgetInstance.key].value.push(value);\n        this.form.controls[this.widgetInstance.key].updateValueAndValidity();\n        return true;\n      }\n    }\n    return false;\n  }\n\n  getDirection(): string {\n    if (\n      this.widgetInstance.type !== SmartFormWidgetType.CONTAINER &&\n      this.widgetInstance.type !== SmartFormWidgetType.CHECK_BOX &&\n      this.widgetInstance.type !== SmartFormWidgetType.RADIO_BUTTON\n    ) {\n      return '';\n    }\n    if (this.widgetInstance.direction === undefined) {\n      return 'direction-row';\n    } else if (this.widgetInstance.direction === SmartFormWidgetDirection.COL) {\n      return 'direction-col';\n    } else {\n      return 'direction-row';\n    }\n  }\n\n  smartFormTextFieldButtonIconPosition(): typeof SmartFormTextFieldButtonIconPosition {\n    return SmartFormTextFieldButtonIconPosition;\n  }\n\n  getType(): typeof SmartFormWidgetType {\n    return SmartFormWidgetType;\n  }\n\n  getWidgetLabel(widget: SmartFormWidget<any>): string {\n    if (widget.type === SmartFormWidgetType.CONTAINER) {\n      return '';\n    }\n    if (widget.label === '') {\n      return widget.label;\n    }\n    let isRequired = false;\n    if (\n      widget.type !== SmartFormWidgetType.LABEL &&\n      widget.type !== SmartFormWidgetType.TIME &&\n      widget.type !== SmartFormWidgetType.INDICATOR &&\n      widget.type !== SmartFormWidgetType.FILE_UPLOADER &&\n      widget.type !== SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n      widget.type !== SmartFormWidgetType.IMAGE &&\n      widget.type !== SmartFormWidgetType.SVG &&\n      widget.type !== SmartFormWidgetType.DIV &&\n      widget.type !== SmartFormWidgetType.DIVIDER &&\n      widget.type !== SmartFormWidgetType.BUTTON &&\n      widget.type !== SmartFormWidgetType.COMPONENT\n    ) {\n      isRequired = widget.validators?.length ? this.fieldIsRequired() && !!widget.showLabel : false;\n    } else if (widget.type === SmartFormWidgetType.LABEL) {\n      isRequired = widget.markAsRequired ? true : false;\n    }\n    return `${widget.label}${isRequired ? ' *' : ''}`;\n  }\n\n  sanitizeHtml(value?: string): SafeHtml | null {\n    let safeValue = value ?? '';\n    return this.sanitizer.bypassSecurityTrustHtml(safeValue);\n  }\n\n  private fieldIsRequired(): boolean {\n    let value = false;\n    if (\n      this.widgetInstance.type !== SmartFormWidgetType.CONTAINER &&\n      this.widgetInstance.type !== SmartFormWidgetType.LABEL &&\n      this.widgetInstance.type !== SmartFormWidgetType.TIME &&\n      this.widgetInstance.type !== SmartFormWidgetType.INDICATOR &&\n      this.widgetInstance.type !== SmartFormWidgetType.FILE_UPLOADER &&\n      this.widgetInstance.type !== SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n      this.widgetInstance.type !== SmartFormWidgetType.IMAGE &&\n      this.widgetInstance.type !== SmartFormWidgetType.SVG &&\n      this.widgetInstance.type !== SmartFormWidgetType.DIV &&\n      this.widgetInstance.type !== SmartFormWidgetType.DIVIDER &&\n      this.widgetInstance.type !== SmartFormWidgetType.BUTTON &&\n      this.widgetInstance.type !== SmartFormWidgetType.COMPONENT &&\n      this.widgetInstance.type !== SmartFormWidgetType.YOUTUBE_PLAYER\n    ) {\n      this.widgetInstance.validators?.forEach((validator: SmartValidator) => {\n        if (validator.validator == Validators.required) value = true;\n      });\n    }\n    return value;\n  }\n\n  public hasCustomError(widget: SmartFormWidget<any>, validator: SmartValidator): boolean {\n    if (\n      widget.type !== SmartFormWidgetType.CONTAINER &&\n      widget.type !== SmartFormWidgetType.LABEL &&\n      widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER\n    ) {\n      if (this.form.controls[widget.key] && this.form.controls[widget.key].errors) {\n        let hasError = Object.keys(this.form.controls[widget.key].errors!).length\n          ? this.form.controls[widget.key]?.dirty ||\n            (this.form.controls[widget.key]?.touched &&\n              validator &&\n              (this.form.controls[widget.key]?.errors)![validator.name])\n          : false;\n        if (\n          (validator && hasError && !this.errorKey) ||\n          (validator && hasError && this.errorKey === validator.name)\n        ) {\n          this.hasError = true;\n          this.errorKey = validator.name;\n        } else if (!hasError && validator && this.errorKey === validator.name) {\n          this.hasError = false;\n          this.errorKey = undefined;\n        } else {\n          hasError = false;\n        }\n        return hasError;\n      }\n    }\n    return false;\n  }\n\n  getErrorMessage(widgetInstance: SmartFormWidget<any>): boolean {\n    let errorMessage: string;\n    let errorIcon: string | undefined;\n    let errorIconColor: string | undefined;\n    let validator: SmartValidator;\n    if (\n      widgetInstance.type !== SmartFormWidgetType.CONTAINER &&\n      widgetInstance.type !== SmartFormWidgetType.LABEL &&\n      widgetInstance.type !== SmartFormWidgetType.INDICATOR &&\n      widgetInstance.type !== SmartFormWidgetType.FILE_UPLOADER &&\n      widgetInstance.type !== SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n      widgetInstance.type !== SmartFormWidgetType.IMAGE &&\n      widgetInstance.type !== SmartFormWidgetType.SVG &&\n      widgetInstance.type !== SmartFormWidgetType.DIV &&\n      widgetInstance.type !== SmartFormWidgetType.DIVIDER &&\n      widgetInstance.type !== SmartFormWidgetType.BUTTON &&\n      widgetInstance.type !== SmartFormWidgetType.COMPONENT &&\n      widgetInstance.type !== SmartFormWidgetType.YOUTUBE_PLAYER\n    ) {\n      if (this.form.controls[widgetInstance.key] && this.form.controls[widgetInstance.key].errors) {\n        if (\n          this.errorKey &&\n          !Object.keys(this.form.controls[widgetInstance.key].errors!).includes(this.errorKey!)\n        ) {\n          this.errorKey = undefined;\n        }\n        for (\n          let index = 0;\n          index < Object.keys(this.form.controls[widgetInstance.key].errors!).length;\n          index++\n        ) {\n          const errorKey = Object.keys(this.form.controls[widgetInstance.key].errors!)[index];\n          let customValidatorOnWidget = widgetInstance.validators?.filter(\n            (validator: SmartValidator) => validator.name === errorKey\n          );\n          if (customValidatorOnWidget && customValidatorOnWidget.length) {\n            errorMessage = customValidatorOnWidget[0].errorMessage!;\n            errorIcon = customValidatorOnWidget[0].icon;\n            errorIconColor = customValidatorOnWidget[0].iconColor;\n            validator = customValidatorOnWidget[0];\n            break;\n          }\n          let customValidatorOnForm = this.service.smartForm?.validators?.filter(\n            (validator: SmartValidator) => validator.name === errorKey\n          );\n          if (customValidatorOnForm && customValidatorOnForm.length) {\n            errorMessage = customValidatorOnForm[0].errorMessage!;\n            validator = customValidatorOnForm[0];\n            break;\n          }\n        }\n      }\n\n      if (this.hasCustomError(widgetInstance, validator!)) {\n        widgetInstance.error = errorMessage!;\n        widgetInstance.errorIcon = errorIcon;\n        widgetInstance.errorIconColor = errorIconColor;\n        return true;\n      }\n\n      if (widgetInstance.serverErrorMessage) {\n        widgetInstance.error = widgetInstance.serverErrorMessage;\n        widgetInstance.errorIcon = widgetInstance.serverErrorIcon;\n        widgetInstance.errorIconColor = widgetInstance.serverErrorColor;\n        return true;\n      }\n\n      widgetInstance.error = undefined;\n    }\n    return false;\n  }\n\n  getIndicatorItemClass(index: number): string {\n    if (this.widgetInstance.type === SmartFormWidgetType.INDICATOR) {\n      if (this.widgetInstance.indicator.indicatorValue >= index) {\n        return `smart-indicator-${index}`;\n      }\n    }\n    return '';\n  }\n\n  getIndicatorStatusLabelColor(): string {\n    if (this.widgetInstance.type !== SmartFormWidgetType.INDICATOR) {\n      return '';\n    }\n    let value = Math.floor(this.widgetInstance.indicator!.indicatorValue);\n    if (value > this.widgetInstance.indicator!.indicatorLength - 1) {\n      return `smart-indicator-label-${this.widgetInstance.indicator!.indicatorLength - 1}`;\n    }\n    return `smart-indicator-label-${value}`;\n  }\n  getIndicatorStatusLabel(): string {\n    if (this.widgetInstance.type !== SmartFormWidgetType.INDICATOR) {\n      return '';\n    }\n    let value = Math.floor(this.widgetInstance.indicator!.indicatorValue);\n    if (value > this.widgetInstance.indicator!.indicatorLength - 1) {\n      return this.widgetInstance.indicator!.indicatorStatusLabels[\n        this.widgetInstance.indicator!.indicatorLength - 1\n      ];\n    }\n    return this.widgetInstance.indicator!.indicatorStatusLabels[value];\n  }\n\n  upload(event: any): void {\n    let type = this.widgetInstance.type;\n\n    if (\n      type !== SmartFormWidgetType.FILE_UPLOADER &&\n      type !== SmartFormWidgetType.MULTI_FILE_UPLOADER\n    ) {\n      return;\n    }\n\n    let params = {\n      ...event.uiAction.params,\n      _files: event.files,\n      param: '_files',\n    };\n    event.uiAction.params = params;\n\n    this.smartComponent.executeUiAction(event.uiAction);\n  }\n\n  executeUiAction(uiAction: UiAction): void {\n    let type = this.widgetInstance.type;\n    if (type !== SmartFormWidgetType.MULTI_FILE_UPLOADER) {\n      return;\n    }\n    this.smartComponent.executeUiAction(uiAction);\n  }\n\n  getButtonType(descriptor: any): string {\n    switch (descriptor.type) {\n      case 'NORMAL':\n        return 'mat-mdc-button';\n      case 'FLAT':\n        return 'mat-mdc-flat-button';\n      case 'RAISED':\n        return 'mat-mdc-raised-button';\n      case 'STROKED':\n        return 'mat-mdc-stroked-button';\n      case 'ICON':\n        return 'mat-mdc-icon-button';\n      case 'MINI_FAB':\n        return 'mat-mdc-mini-fab';\n      case 'FAB':\n        return 'mat-mdc-fab';\n      default:\n        console.log(`Unhandled action button type case: ${descriptor.type}`);\n        return `mat-button`;\n    }\n  }\n\n  isOnlyIcon(descriptor: any): boolean {\n    return (\n      descriptor.type === 'ICON' || descriptor.type === 'MINI_FAB' || descriptor.type === 'FAB'\n    );\n  }\n\n  onButtonClicked(instance: SmartButton): void {\n    if (instance.uiAction) {\n      instance.callback(instance.uiAction);\n    } else {\n      instance.callback(instance.key);\n    }\n  }\n\n  private _filter(value: InputEvent): SmartItem<any>[] {\n    let filterValue = (value.target as HTMLInputElement)?.value;\n    this.toHighlight = filterValue;\n\n    if (!filterValue) {\n      filterValue = '';\n      this.toHighlight = filterValue;\n    }\n    filterValue = filterValue.toLowerCase();\n\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_FIELD &&\n      this.widgetInstance.valueList\n    ) {\n      const result: SmartItem<any>[] = filterValue\n        ? this.widgetInstance.valueList.filter((option: SmartItem<any>) =>\n            option.label.toLowerCase().includes(filterValue)\n          )\n        : this.widgetInstance.valueList;\n      if (result.length === 0 && this.widgetInstance.valueList.length !== 0) {\n        // there could be values after the filter operation but we found none:\n        this.widgetInstance.error = this.widgetInstance.filterErrorMessage;\n      } else {\n        // we either found values, or there were no values to begin with:\n        this.widgetInstance.error = undefined;\n      }\n      return result;\n    }\n\n    return [];\n  }\n\n  dateFilter(d: Date | null): boolean {\n    return true;\n  }\n\n  getMatrixDisplayValue(question: Value, key: string) {\n    (this.widgetInstance as SmartMatrix).value[key].find((value: Value) => {\n      if (value.code == question.code) return question.displayValue;\n      else return question.code;\n    });\n  }\n\n  handleYearMonthPicked(yearMonthValue: any) {\n    this.setDateFormControl(this.form.controls[this.widgetInstance.key!], yearMonthValue, '00:00');\n  }\n\n  compareItems(o1: any, o2: any): boolean {\n    function convert(obj: any): any {\n      if (obj && typeof obj === 'string') {\n        return obj.replace(/\\.v[0-9]+$/, '');\n      }\n      return obj;\n    }\n    // calling this.truncateUri didn't work\n    // TODO: use widget.selection.parameter for ignoreUriVersion / strictUriComparison;\n\n    let v1 = convert(o1);\n    let v2 = convert(o2);\n    return deepEqual(v1, v2);\n  }\n\n  truncateUri(uri: any): any {\n    if (uri && typeof uri === 'string') {\n      return uri.replace(/\\.v[0-9]+$/, '');\n    }\n    return uri;\n  }\n\n  removeMatrixRow(question: any): void {\n    console.log(question);\n    (this.widgetInstance as SmartMatrix).button?.callback(this.widgetInstance, question);\n  }\n\n  isToolbarPresent(): boolean {\n    if (\n      this.widgetInstance.type == SmartFormWidgetType.TEXT_FIELD ||\n      this.widgetInstance.type == SmartFormWidgetType.TEXT_FIELD_LOOKUP ||\n      this.widgetInstance.type == SmartFormWidgetType.FILE_UPLOADER ||\n      this.widgetInstance.type == SmartFormWidgetType.MULTI_FILE_UPLOADER\n    ) {\n      return this.widgetInstance.toolbarId !== undefined && this.widgetInstance.toolbarId !== null;\n    }\n    return false;\n  }\n  getChipsValue(value: any): any {\n    if (typeof value === 'object' && !Array.isArray(value) && value !== null) {\n      if ('name' in value) {\n        return value['name'];\n      }\n      if ('displayValue' in value) {\n        return value['displayValue'];\n      }\n    }\n    return value;\n  }\n  getOptions(items: SmartItems<any>[]) {\n    let values: any[] = [];\n    items.map((item) => {\n      if (item.type === SmartFormWidgetType.ITEM_GROUP) {\n        item.valueList.map((value: SmartItem<any>) => {\n          values.push(value);\n        });\n      } else if (item.type === SmartFormWidgetType.ITEM) {\n        values.push(item);\n      }\n    });\n\n    return values;\n  }\n\n  get clearButtonDescriptor(): UiActionDescriptor {\n    return {\n      title: '',\n      color: 'primary',\n      type: UiActionButtonType.RAISED,\n      icon: this.compLib === ComponentLibrary.PRIMENG ? 'times' : 'close',\n      iconPosition: IconPosition.PRE,\n    };\n  }\n\n  clearField(key: string) {\n    this.form.controls[key].setValue('');\n    this.onBlur?.next(this.widgetInstance);\n  }\n\n  onTextareaChange(value: string) {\n    const ta = this.sb4Textarea?.nativeElement;\n    if (!ta) return;\n\n    if (document.activeElement === ta) {\n      return;\n    }\n\n    requestAnimationFrame(() => {\n      ta.style.height = 'auto';\n      ta.style.height = `${ta.scrollHeight}px`;\n    });\n  }\n\n  handleBlurEvent(eventData: any) {\n    this.onBlur?.next(eventData);\n    this.blurSophisticatedValueChange.next({\n      key: this.widgetInstance.key!,\n      kind: this.getSophisticatedEventKind(),\n      value: this.form.value[this.widgetInstance.key!],\n    });\n  }\n\n  dorpdownOpening = true;\n  onDropDownShow() {\n    this.dorpdownOpening = true;\n  }\n  onDropDownInput() {\n    if (this.dorpdownOpening == true) {\n      this.dorpdownOpening = false;\n    }\n  }\n\n  safeDropDownBlur(event: any) {\n    // We do not use the first blur event after the calendar picker opens,\n    // as it \"eats\" the first click\n\n    if (this.dorpdownOpening) {\n      this.dorpdownOpening = false;\n      return;\n    }\n\n    this.handleBlurEvent(event);\n  }\n\n  calendarOpening = false;\n  onCalendarShow() {\n    this.calendarOpening = true;\n  }\n  onCalendarInput() {\n    if (this.calendarOpening == true) {\n      this.calendarOpening = false;\n    }\n  }\n\n  safeCalendarBlur(event: any) {\n    // We do not use the first blur event after the calendar picker opens,\n    // as it \"eats\" the first click\n\n    if (this.calendarOpening) {\n      this.calendarOpening = false;\n      return;\n    }\n\n    this.handleBlurEvent(event);\n  }\n\n  convertToLocalDateTime(value: string | null): Date | null {\n    if (!value) return null;\n\n    let parsed = new Date(value);\n\n    if (isNaN(parsed.getTime())) {\n      console.error('Invalid Date:', value);\n      return null;\n    }\n\n    return new Date(\n      parsed.getFullYear(),\n      parsed.getMonth(),\n      parsed.getDate(),\n      parsed.getHours(),\n      parsed.getMinutes(),\n      parsed.getSeconds()\n    );\n  }\n\n  getControlMessages(controlName: string) {\n    const control = this.form.controls[controlName];\n    const errors = this.form.controls[controlName]?.errors ?? {};\n\n    this.errorMessages = Object.keys(errors)\n      .filter((key) => typeof errors[key] === 'string')\n      .map((key) => ({\n        severity: 'error',\n        detail: errors[key],\n      }));\n\n    if (this.errorMessages.length === 0) {\n      if (\n        this.widgetInstance.type !== SmartFormWidgetType.CONTAINER &&\n        this.widgetInstance.type !== SmartFormWidgetType.LABEL &&\n        this.widgetInstance.type !== SmartFormWidgetType.INDICATOR &&\n        this.widgetInstance.type !== SmartFormWidgetType.FILE_UPLOADER &&\n        this.widgetInstance.type !== SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n        this.widgetInstance.type !== SmartFormWidgetType.IMAGE &&\n        this.widgetInstance.type !== SmartFormWidgetType.SVG &&\n        this.widgetInstance.type !== SmartFormWidgetType.DIV &&\n        this.widgetInstance.type !== SmartFormWidgetType.DIVIDER &&\n        this.widgetInstance.type !== SmartFormWidgetType.BUTTON &&\n        this.widgetInstance.type !== SmartFormWidgetType.COMPONENT &&\n        this.widgetInstance.type !== SmartFormWidgetType.YOUTUBE_PLAYER\n      ) {\n        if (Object.keys(errors).length > 0) {\n          this.errorMessages.push({\n            severity: 'error',\n            detail: this.widgetInstance.serverErrorMessage,\n          });\n        }\n      }\n    }\n  }\n}\n","@if (compLib === componentLibrary.PRIMENG) {\n  <div class=\"container prime\" [formGroup]=\"form\">\n    <div\n      [ngClass]=\"widgetInstance.cssClass ?? ''\"\n      class=\"container\"\n      *ngIf=\"widgetInstance.isVisible === undefined ? true : widgetInstance.isVisible\"\n    >\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CONTAINER\" [ngClass]=\"getDirection()\">\n        <smartformwidget\n          *ngFor=\"let widget of widgetInstance.valueList\"\n          [form]=\"form\"\n          [widgetInstance]=\"widget\"\n          class=\"container-item\"\n          [ngClass]=\"widget.cssClass ?? ''\"\n          [onBlur]=\"onBlur\"\n          [onValueChange]=\"onValueChange\"\n          [sophisticatedValueChange]=\"sophisticatedValueChange\"\n          [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\n          class=\"{{ widget.key }}\"\n          [labelColor]=\"labelColor\"\n        ></smartformwidget>\n      </div>\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer textFieldContainer\">\n          <p-floatLabel [ngClass]=\"{ hasToolbar: isToolbarPresent() }\">\n            <input\n              *ngIf=\"!widgetInstance.mask\"\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              type=\"{{ widgetInstance.isPassword ? (hidePassword ? 'password' : 'text') : '' }}\"\n              pInputText\n              formControlName=\"text\"\n              (change)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n            />\n            <p-inputMask\n              *ngIf=\"widgetInstance.mask\"\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              [mask]=\"widgetInstance.mask\"\n              (onBlur)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n            />\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n          <div class=\"textFieldButtons\">\n            <smart-ui-action-toolbar\n              #toolbar\n              *ngIf=\"isToolbarPresent()\"\n              class=\"textFieldToolbar\"\n              matSuffix\n              [id]=\"widgetInstance.toolbarId\"\n            >\n            </smart-ui-action-toolbar>\n            @if (widgetInstance.textFieldProperties?.clearable) {\n              <ui-action-button\n                class=\"clearButton\"\n                [addBasicClasses]=\"false\"\n                [descriptor]=\"clearButtonDescriptor\"\n                (actionClick)=\"clearField(widgetInstance.key)\"\n              />\n            }\n          </div>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_NUMBER\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-inputNumber\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              inputId=\"minmax\"\n              mode=\"decimal\"\n              [max]=\"widgetInstance.maxValues ?? null\"\n              [minFractionDigits]=\"0\"\n              [maxFractionDigits]=\"5\"\n              (onBlur)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n            />\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.RICH_TEXT\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div class=\"labelContainer\">\n          <div *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </div>\n        </div>\n        <div>\n          <div class=\"widgetContent\">\n            <p-editor\n              [ngClass]=\"widgetInstance.isReadonly == true ? 'disabledEditor' : ''\"\n              [formControlName]=\"widgetInstance.key\"\n              [id]=\"widgetInstance.key\"\n              [modules]=\"\n                widgetInstance.isDisabled ? emptyQuillToolbar : widgetInstance.quillModules\n              \"\n              [placeholder]=\"widgetInstance.placeholder\"\n              [readOnly]=\"widgetInstance.isReadonly\"\n              [disabled]=\"widgetInstance.isReadonly ?? false\"\n              [maxLength]=\"widgetInstance.maxLength\"\n              (onTextChange)=\"onPrimeRichTextEditorContentChanged($event)\"\n              (onTextChange)=\"handleBlurEvent($event)\"\n            />\n          </div>\n          <span class=\"prime-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.SORTABLE\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div class=\"labelContainer\">\n          <h4 *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n        </div>\n        <div class=\"widgetContent\">\n          <lib-sortable-widget\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n          ></lib-sortable-widget>\n        </div>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_PICKER\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-calendar\n              [formControlName]=\"widgetInstance.key\"\n              [iconDisplay]=\"'input'\"\n              [showIcon]=\"true\"\n              [minDate]=\"\n                convertToLocalDateTime(widgetInstance.dateFieldProperties?.minDate ?? null)\n              \"\n              [maxDate]=\"\n                convertToLocalDateTime(widgetInstance.dateFieldProperties?.maxDate ?? null)\n              \"\n              [showClear]=\"true\"\n              (onShow)=\"onCalendarShow()\"\n              (onInput)=\"onCalendarInput()\"\n              (onBlur)=\"safeCalendarBlur($event)\"\n              (onClear)=\"handleBlurEvent($event)\"\n              (onClose)=\"handleBlurEvent($event)\"\n              dateFormat=\"yy-mm-dd\"\n              appendTo=\"body\"\n            />\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_TIME_PICKER\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-calendar\n              [formControlName]=\"widgetInstance.key\"\n              [iconDisplay]=\"'input'\"\n              [showIcon]=\"true\"\n              [showTime]=\"true\"\n              [showClear]=\"true\"\n              [minDate]=\"\n                convertToLocalDateTime(widgetInstance.dateFieldProperties?.minDate ?? null)\n              \"\n              [maxDate]=\"\n                convertToLocalDateTime(widgetInstance.dateFieldProperties?.maxDate ?? null)\n              \"\n              hourFormat=\"24\"\n              (onShow)=\"onCalendarShow()\"\n              (onInput)=\"onCalendarInput()\"\n              (onBlur)=\"safeCalendarBlur($event)\"\n              (onClear)=\"handleBlurEvent($event)\"\n              (onClose)=\"handleBlurEvent($event)\"\n              dateFormat=\"yy-mm-dd\"\n              appendTo=\"body\"\n            >\n            </p-calendar>\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.SELECT\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-dropdown\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              [options]=\"getOptions(widgetInstance.valueList)\"\n              [checkmark]=\"true\"\n              [filter]=\"true\"\n              [showClear]=\"true\"\n              (onBlur)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n              [compareWith]=\"\n                widgetInstance.compareWith == null ? compareItems : widgetInstance.compareWith\n              \"\n              appendTo=\"body\"\n            />\n            <span class=\"prime-error\">\n              {{ widgetInstance.error }}\n            </span>\n            <smart-icon\n              *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n              [icon]=\"widgetInstance.errorIcon\"\n              [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              matSuffix\n            ></smart-icon>\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.SELECT_MULTIPLE\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-multiSelect\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              [options]=\"getOptions(widgetInstance.valueList)\"\n              [checkmark]=\"true\"\n              [showClear]=\"true\"\n              (onPanelShow)=\"onDropDownShow()\"\n              (onBlur)=\"safeDropDownBlur($event)\"\n              (onClear)=\"handleBlurEvent($event)\"\n              (onPanelHide)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n              [compareWith]=\"\n                widgetInstance.compareWith == null ? compareItems : widgetInstance.compareWith\n              \"\n              appendTo=\"body\"\n              selectedItemsLabel=\"{0} elem kiválasztva\"\n            />\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_BOX\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\" [ngClass]=\"getNgClass()\" [ngStyle]=\"getStyle()\">\n          <p-floatLabel>\n            <textarea\n              class=\"sb4-textarea\"\n              #sb4Textarea\n              pInputTextarea\n              [autoResize]=\"true\"\n              cols=\"30\"\n              [rows]=\"widgetInstance.textBoxProperties?.minRows ?? 1\"\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              placeholder=\" \"\n              [id]=\"widgetInstance.key\"\n              (change)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n              (ngModelChange)=\"onTextareaChange($event)\"\n            ></textarea>\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n              [for]=\"widgetInstance.key\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_LOOKUP\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-chips\n              [disabled]=\"widgetInstance.isDisabled ? widgetInstance.isDisabled : false\"\n              [max]=\"0\"\n              [maxLength]=\"0\"\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              (onBlur)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n            >\n              <ng-template let-item pTemplate=\"item\"> {{ getChipsValue(item) }} </ng-template>\n            </p-chips>\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n          <smart-ui-action-toolbar\n            #toolbar\n            *ngIf=\"isToolbarPresent()\"\n            matSuffix\n            [id]=\"widgetInstance.toolbarId\"\n          ></smart-ui-action-toolbar>\n        </div>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.LABEL\"\n        class=\"label widgetContainer\"\n        [ngStyle]=\"{ width: widgetInstance.minWidth + 'px' }\"\n      >\n        <div class=\"label-title labelContainer\" [ngClass]=\"widgetInstance.cssClass ?? ''\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{ widgetInstance.cssClass ?? '' }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          @if (widgetInstance.widgetDescription) {\n            <p>{{ widgetInstance.widgetDescription }}</p>\n          }\n        </div>\n      </div>\n      @if (widgetInstance.type === smartFormWidgetType.FILE_UPLOADER) {\n        <div class=\"widgetContainer\">\n          <smart-file-editor\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n            (uploadFilesEvent)=\"upload($event)\"\n          />\n        </div>\n      }\n\n      @if (widgetInstance.type === smartFormWidgetType.MULTI_FILE_UPLOADER) {\n        <div class=\"widgetContainer\">\n          <smart-multi-file-editor\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n            (uploadFilesEvent)=\"upload($event)\"\n            (fileEvent)=\"executeUiAction($event.uiAction)\"\n          />\n        </div>\n      }\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.IMAGE\"\n        class=\"widgetContainer imageContainer\"\n      >\n        <h4\n          *ngIf=\"widgetInstance.showLabel && getWidgetLabel(widgetInstance)\"\n          class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n\n        @if (widgetInstance.imageProperties?.image) {\n          <smart-icon\n            [imageResource]=\"widgetInstance.imageProperties!.image\"\n            class=\"widgetContent {{ widgetInstance.imageCss ?? '' }}\"\n            alt=\"Image\"\n            title=\"{{ widgetInstance.key }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          ></smart-icon>\n        } @else if (widgetInstance.value) {\n          <smart-icon\n            [imageResource]=\"widgetInstance.value\"\n            class=\"widgetContent {{ widgetInstance.imageCss ?? '' }}\"\n            alt=\"Image\"\n            title=\"{{ widgetInstance.key }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          ></smart-icon>\n        }\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TOGGLE\"\n        class=\"widgetContainer toggle-col\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <label [ngClass]=\"widgetInstance.cssLabelClass ?? ''\" [for]=\"widgetInstance.key\">\n          {{ getWidgetLabel(widgetInstance) }}\n        </label>\n        <p-inputSwitch\n          formControlName=\"{{ widgetInstance.key }}\"\n          [(ngModel)]=\"widgetInstance.value\"\n          [id]=\"widgetInstance.key\"\n          name=\"{{ getWidgetLabel(widgetInstance) }}\"\n          (onChange)=\"onValueChange?.next($event)\"\n          (onChange)=\"handleBlurEvent($event)\"\n        />\n      </div>\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CHECK_BOX\" class=\"widgetContainer\">\n        <div\n          class=\"input checkbox widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <section class=\"checkbox-section\" [ngClass]=\"getDirection()\">\n            <div class=\"checkbox-item-container\">\n              <p-checkbox\n                class=\"selecatbleObject\"\n                formControlName=\"{{ widgetInstance.key }}\"\n                [binary]=\"true\"\n                [label]=\"widgetInstance.label\"\n              />\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </section>\n        </div>\n      </div>\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CHECK_BOX_2\" class=\"widgetContainer\">\n        <div\n          class=\"input checkbox widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <section class=\"checkbox-section\" [ngClass]=\"getDirection()\">\n            <div\n              class=\"checkbox-item-container\"\n              *ngFor=\"let checkbox of widgetInstance.valueList; let i = index\"\n            >\n              <img\n                *ngIf=\"checkbox.imageUrl\"\n                title=\"{{ widgetInstance.key }}\"\n                class=\"checkbox-item-image\"\n                [src]=\"checkbox.imageUrl\"\n              />\n              <p-checkbox\n                class=\"selecatbleObject\"\n                formControlName=\"{{ widgetInstance.key + '.' + checkbox.key }}\"\n                [ngModel]=\"checkbox.value\"\n                [binary]=\"true\"\n                [label]=\"checkbox.label\"\n              />\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </section>\n        </div>\n      </div>\n\n      @if (widgetInstance.type === smartFormWidgetType.DIV) {\n        <div class=\"widgetContainer\">\n          <div\n            class=\"smartDiv\"\n            [innerHTML]=\"sanitizeHtml(getWidgetLabel(widgetInstance))\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          >\n          </div>\n        </div>\n      }\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.SVG\" class=\"widgetContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div\n          class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [innerHTML]=\"sanitizeHtml(widgetInstance.value)\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        ></div>\n      </div>\n    </div>\n  </div>\n} @else {\n  <div class=\"container material\" [formGroup]=\"form\">\n    <div\n      [ngClass]=\"widgetInstance.cssClass ?? ''\"\n      class=\"container\"\n      *ngIf=\"widgetInstance.isVisible === undefined ? true : widgetInstance.isVisible\"\n    >\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CONTAINER\" [ngClass]=\"getDirection()\">\n        <smartformwidget\n          *ngFor=\"let widget of widgetInstance.valueList\"\n          [form]=\"form\"\n          [widgetInstance]=\"widget\"\n          class=\"container-item\"\n          [ngClass]=\"widget.cssClass ?? ''\"\n          [onBlur]=\"onBlur\"\n          [onValueChange]=\"onValueChange\"\n          [sophisticatedValueChange]=\"sophisticatedValueChange\"\n          class=\"{{ widget.key }}\"\n          [labelColor]=\"labelColor\"\n        ></smartformwidget>\n      </div>\n\n      <div\n        (capsLock)=\"capsOn = $event\"\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input textField widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n\n          <input\n            *ngIf=\"!widgetInstance.selection\"\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [attr.inputmode]=\"\n              widgetInstance.inputMode ? widgetInstance.inputMode.toLocaleLowerCase() : 'text'\n            \"\n            [type]=\"'string'\"\n            [value]=\"widgetInstance.value\"\n            [readonly]=\"widgetInstance.isReadonly\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            matInput\n            (change)=\"handleBlurEvent($event)\"\n            (input)=\"onValueChange?.next($event)\"\n            type=\"{{ widgetInstance.isPassword ? (hidePassword ? 'password' : 'text') : '' }}\"\n            (keydown.enter)=\"onKeydown()\"\n            maxlength=\"{{ widgetInstance.maxLength }}\"\n          />\n          <!-- [mask]=\"widgetInstance.mask ?? ''\" -->\n          <input\n            *ngIf=\"widgetInstance.selection\"\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [type]=\"'string'\"\n            [value]=\"widgetInstance.value\"\n            [readonly]=\"widgetInstance.isReadonly\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            matInput\n            (change)=\"handleBlurEvent($event)\"\n            (input)=\"onValueChange?.next($event)\"\n            type=\"{{ widgetInstance.isPassword ? 'password' : '' }}\"\n            [matAutocomplete]=\"textFieldAuto\"\n            (keydown.enter)=\"onKeydown()\"\n          />\n          <button\n            *ngIf=\"widgetInstance.isPassword\"\n            mat-icon-button\n            matSuffix\n            (click)=\"togglePasswordVisibility($event)\"\n          >\n            <mat-icon>{{ hidePassword ? 'visibility_off' : 'visibility' }}</mat-icon>\n          </button>\n          <mat-autocomplete #textFieldAuto=\"matAutocomplete\">\n            <mat-option *ngFor=\"let option of filteredOptions | async\" [value]=\"option.label\">\n              <span [innerHTML]=\"option.label | highlight: toHighlight\"></span>\n            </mat-option>\n          </mat-autocomplete>\n          <span class=\"mat-error\" *ngIf=\"capsOn && widgetInstance.isPassword\">\n            {{ widgetInstance.capsLockWarning }}\n          </span>\n\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n\n          <span matPrefix>\n            <smart-icon\n              *ngIf=\"capsOn && widgetInstance.isPassword\"\n              [icon]=\"widgetInstance.capsLockWarningIcon ?? 'keyboard_capslock'\"\n              color=\"warn\"\n            ></smart-icon>\n            <smart-icon\n              *ngIf=\"widgetInstance.icon && widgetInstance.iconPosition === 'PRE'\"\n              [icon]=\"widgetInstance.icon\"\n              [color]=\"widgetInstance.iconColor ?? 'primary'\"\n            ></smart-icon>\n            {{ widgetInstance.prefix }}\n          </span>\n          <span matSuffix>\n            {{ widgetInstance.suffix }}\n          </span>\n          <smart-icon\n            *ngIf=\"\n              widgetInstance.icon &&\n              (!widgetInstance.iconPosition || widgetInstance.iconPosition === 'POST')\n            \"\n            [icon]=\"widgetInstance.icon\"\n            [color]=\"widgetInstance.iconColor ?? 'primary'\"\n            matSuffix\n          ></smart-icon>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n          <div class=\"textFieldButtons\">\n            @if (widgetInstance.textFieldProperties?.clearable) {\n              <ui-action-button\n                class=\"clearButton\"\n                [addBasicClasses]=\"false\"\n                [descriptor]=\"clearButtonDescriptor\"\n                (actionClick)=\"clearField(widgetInstance.key)\"\n              />\n            }\n          </div>\n          <smart-ui-action-toolbar\n            #toolbar\n            *ngIf=\"isToolbarPresent()\"\n            class=\"textFieldToolbar\"\n            matSuffix\n            [id]=\"widgetInstance.toolbarId\"\n          ></smart-ui-action-toolbar>\n          <button\n            *ngIf=\"widgetInstance.textFieldButton\"\n            matSuffix\n            mat-button\n            color=\"{{ widgetInstance.textFieldButton.color }}\"\n            (click)=\"widgetInstance.textFieldButton.callback(widgetInstance)\"\n          >\n            <smart-icon\n              *ngIf=\"\n                widgetInstance.textFieldButton.iconPosition ===\n                  smartFormTextFieldButtonIconPosition().PRE && widgetInstance.textFieldButton.icon\n              \"\n              [icon]=\"widgetInstance.textFieldButton.icon\"\n              [color]=\"widgetInstance.textFieldButton.iconColor\"\n            >\n            </smart-icon>\n            {{ widgetInstance.textFieldButton.label }}\n            <smart-icon\n              *ngIf=\"\n                widgetInstance.textFieldButton.iconPosition ===\n                  smartFormTextFieldButtonIconPosition().POST && widgetInstance.textFieldButton.icon\n              \"\n              [icon]=\"widgetInstance.textFieldButton.icon\"\n            >\n            </smart-icon>\n          </button>\n          <mat-hint\n            *ngIf=\"widgetInstance.showCharacterLimitSuffix && widgetInstance.maxLength\"\n            matSuffix\n            align=\"end\"\n            >{{\n              widgetInstance.maxLength - form.controls[widgetInstance.key].value.length\n            }}</mat-hint\n          >\n        </mat-form-field>\n        <mat-hint\n          *ngIf=\"\n            !widgetInstance?.hint ||\n            widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n          \"\n          >{{ widgetInstance.hint?.text }}</mat-hint\n        >\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_NUMBER\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input textField widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <input\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [value]=\"widgetInstance.value\"\n            [readonly]=\"widgetInstance.isReadonly\"\n            [type]=\"'number'\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            [min]=\"widgetInstance.minValues ?? null\"\n            [max]=\"widgetInstance.maxValues ?? null\"\n            matInput\n            (change)=\"handleBlurEvent($event)\"\n            (input)=\"onValueChange?.next($event)\"\n          />\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <span matPrefix>\n            {{ widgetInstance.prefix }}\n          </span>\n          <span matSuffix>\n            {{ widgetInstance.suffix }}\n          </span>\n          <smart-icon *ngIf=\"widgetInstance.icon\" [icon]=\"widgetInstance.icon\" matSuffix>\n          </smart-icon>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n          <button\n            *ngIf=\"widgetInstance.textFieldButton\"\n            matSuffix\n            mat-button\n            color=\"{{ widgetInstance.textFieldButton.color }}\"\n            (click)=\"widgetInstance.textFieldButton.callback(widgetInstance)\"\n          >\n            <smart-icon\n              *ngIf=\"\n                widgetInstance.textFieldButton.iconPosition ===\n                  smartFormTextFieldButtonIconPosition().PRE && widgetInstance.textFieldButton.icon\n              \"\n              [icon]=\"widgetInstance.textFieldButton.icon\"\n            >\n            </smart-icon>\n            {{ widgetInstance.textFieldButton.label }}\n            <smart-icon\n              *ngIf=\"\n                widgetInstance.textFieldButton.iconPosition ===\n                  smartFormTextFieldButtonIconPosition().POST && widgetInstance.textFieldButton.icon\n              \"\n              [icon]=\"widgetInstance.textFieldButton.icon\"\n            >\n            </smart-icon>\n          </button>\n        </mat-form-field>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_CHIPS\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-chip-grid #chipList aria-label=\"{{ widgetInstance.label }}\">\n            <mat-chip-row\n              [disabled]=\"widgetInstance.isDisabled\"\n              *ngFor=\"let value of widgetInstance.value\"\n              (removed)=\"remove(value)\"\n            >\n              {{ value }}\n              <button matChipRemove>\n                <mat-icon>cancel</mat-icon>\n              </button>\n            </mat-chip-row>\n            <input\n              #chipInput\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              [matChipInputFor]=\"chipList\"\n              [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\n              [matChipInputAddOnBlur]=\"addOnBlur\"\n              [readonly]=\"widgetInstance.isReadonly\"\n              [matAutocomplete]=\"chipAuto\"\n              (matChipInputTokenEnd)=\"add($event)\"\n              (change)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n              [disabled]=\"widgetInstance.isDisabled\"\n            />\n            <mat-autocomplete\n              #chipAuto=\"matAutocomplete\"\n              (optionSelected)=\"selected($event, widgetInstance)\"\n            >\n              <mat-option\n                [disabled]=\"widgetInstance.isDisabled\"\n                *ngFor=\"let item of widgetInstance.valueList\"\n                [value]=\"item.value\"\n              >\n                {{ item.label }}\n              </mat-option>\n            </mat-autocomplete>\n          </mat-chip-grid>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n        </mat-form-field>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_LOOKUP\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-chip-grid #chipListLookup aria-label=\"{{ widgetInstance.label }}\">\n            <mat-chip\n              [disabled]=\"widgetInstance.isDisabled\"\n              *ngFor=\"let value of widgetInstance.value\"\n              (removed)=\"remove(value)\"\n            >\n              {{ getChipsValue(value) }}\n              <button matChipRemove>\n                <mat-icon>cancel</mat-icon>\n              </button>\n            </mat-chip>\n            <input\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              [matChipInputFor]=\"chipListLookup\"\n              [matChipInputSeparatorKeyCodes]=\"emptySeparatorKeysCodes\"\n              [matChipInputAddOnBlur]=\"false\"\n              [readonly]=\"true\"\n              [disabled]=\"widgetInstance.isDisabled\"\n            />\n          </mat-chip-grid>\n          <smart-ui-action-toolbar\n            #toolbar\n            *ngIf=\"isToolbarPresent()\"\n            matSuffix\n            [id]=\"widgetInstance.toolbarId\"\n          ></smart-ui-action-toolbar>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n        </mat-form-field>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_BOX\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <textarea\n            class=\"sb4-textarea\"\n            #sb4Textarea\n            cols=\"30\"\n            cdkTextareaAutosize\n            [cdkAutosizeMinRows]=\"widgetInstance.textBoxProperties?.minRows ?? 1\"\n            [cdkAutosizeMaxRows]=\"widgetInstance.textBoxProperties?.maxRows ?? undefined\"\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [type]=\"'string'\"\n            [value]=\"widgetInstance.value\"\n            [readonly]=\"widgetInstance.isReadonly\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            matInput\n            (change)=\"handleBlurEvent($event)\"\n            maxlength=\"{{ widgetInstance.maxLength }}\"\n          ></textarea>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n          <mat-hint\n            *ngIf=\"widgetInstance.showCharacterLimitSuffix && widgetInstance.maxLength\"\n            matSuffix\n            align=\"end\"\n            >{{\n              widgetInstance.maxLength - form.controls[widgetInstance.key].value.length\n            }}</mat-hint\n          >\n        </mat-form-field>\n        <mat-hint\n          *ngIf=\"\n            !widgetInstance.hint || widgetInstance.hint?.position === SmartWidgetHintPosition.INPUT\n          \"\n          >{{ widgetInstance.hint?.text }}</mat-hint\n        >\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CHECK_BOX\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div\n          class=\"input checkbox widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label class=\"radioLabel\" *ngIf=\"!widgetInstance.showLabel\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <section class=\"checkbox-section\" [ngClass]=\"getDirection()\">\n            <div class=\"checkbox-item-container\">\n              <mat-checkbox\n                class=\"selecatbleObject\"\n                formControlName=\"{{ widgetInstance.key }}\"\n                (change)=\"onValueChange?.next(widgetInstance)\"\n              >\n                {{ widgetInstance.label }}\n              </mat-checkbox>\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </section>\n        </div>\n      </div>\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CHECK_BOX_2\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{ widgetInstance.cssLabelClass }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div\n          class=\"input checkbox widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label class=\"radioLabel\" *ngIf=\"!widgetInstance.showLabel\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <section class=\"checkbox-section\" [ngClass]=\"getDirection()\">\n            <div\n              class=\"checkbox-item-container\"\n              *ngFor=\"let checkbox of widgetInstance.valueList; let i = index\"\n            >\n              <img\n                *ngIf=\"checkbox.imageUrl\"\n                title=\"{{ widgetInstance.key }}\"\n                class=\"checkbox-item-image\"\n                [src]=\"checkbox.imageUrl\"\n              />\n              <mat-checkbox\n                class=\"selecatbleObject\"\n                formControlName=\"{{ widgetInstance.key + '.' + checkbox.key }}\"\n                [value]=\"checkbox.value\"\n                (change)=\"onValueChange?.next(checkbox)\"\n                [disabled]=\"widgetInstance.isDisabled!\"\n              >\n                {{ checkbox.label }}\n              </mat-checkbox>\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </section>\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.RADIO_BUTTON\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{ widgetInstance.cssLabelClass }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-radio-group\n          class=\"input radio-section widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          aria-label=\"{{ widgetInstance.label }}\"\n          appearance=\"outline\"\n          formControlName=\"{{ widgetInstance.key }}\"\n        >\n          <mat-label class=\"radioLabel\" *ngIf=\"!widgetInstance.showLabel\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <div [ngClass]=\"getDirection()\">\n            <div class=\"radio-item-container\" *ngFor=\"let radio of widgetInstance.valueList\">\n              <img\n                *ngIf=\"radio.imageUrl\"\n                title=\"{{ widgetInstance.key }}\"\n                class=\"radio-item-image\"\n                [src]=\"radio.imageUrl\"\n              />\n              <mat-radio-button\n                class=\"selecatbleObject\"\n                value=\"{{ radio.value }}\"\n                [ngClass]=\"getDirection()\"\n                (change)=\"onValueChange?.next(radio.value)\"\n                [disabled]=\"widgetInstance.isDisabled\"\n              >\n                {{ radio.label }}\n              </mat-radio-button>\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </div>\n        </mat-radio-group>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_PICKER\"\n        class=\"datePicker widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent date {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n          <mat-datepicker #picker (closed)=\"handleBlurEvent(widgetInstance)\"></mat-datepicker>\n          <input\n            matInput\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [value]=\"widgetInstance.value\"\n            [min]=\"convertToLocalDateTime(widgetInstance.dateFieldProperties?.minDate ?? null)\"\n            [max]=\"convertToLocalDateTime(widgetInstance.dateFieldProperties?.maxDate ?? null)\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            [matDatepicker]=\"picker\"\n            (change)=\"handleBlurEvent(widgetInstance)\"\n            (dateChange)=\"onValueChange?.next(widgetInstance)\"\n            [matDatepickerFilter]=\"widgetInstance.filter ?? dateFilter\"\n          />\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n          <mat-hint>\n            {{ widgetInstance.dateFormatHint }}\n          </mat-hint>\n        </mat-form-field>\n      </div>\n\n      <!-- <div\n      *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_TIME_PICKER\"\n      class=\"widgetContainer\"\n    >\n      <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n        <h4 class=\"{{ labelColor }} smart-form-widget-label\">\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n      </div>\n      <mat-form-field\n        class=\"input widgetContent\"\n        [ngClass]=\"widgetInstance.cssClass ?? ''\"\n        [ngStyle]=\"{ width: widgetInstance.minWidth + 'px' }\"\n        appearance=\"outline\"\n      >\n        <mat-label\n          class=\"label\"\n          [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n          *ngIf=\"!widgetInstance.showLabel\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </mat-label>\n        <mat-datepicker-toggle matSuffix [for]=\"$any(picker)\"></mat-datepicker-toggle>\n        <ngx-mat-datetime-picker\n          #picker\n          [showSpinners]=\"true\"\n          [showSeconds]=\"false\"\n          [stepHour]=\"1\"\n          [stepMinute]=\"1\"\n          [stepSecond]=\"10\"\n          [touchUi]=\"false\"\n          [color]=\"'primary'\"\n          [enableMeridian]=\"false\"\n          [disableMinute]=\"false\"\n          [hideTime]=\"false\"\n        >\n        </ngx-mat-datetime-picker>\n        <input\n          matInput\n          [formControlName]=\"widgetInstance.key\"\n          [id]=\"widgetInstance.key\"\n          [value]=\"widgetInstance.value\"\n          placeholder=\"{{ widgetInstance.placeholder }}\"\n          [ngxMatDatetimePicker]=\"picker\"\n          [ngxMatDatetimePickerFilter]=\"widgetInstance.filter ?? dateFilter\"\n          (blur)=\"onBlur?.next(widgetInstance)\"\n        />\n        <span class=\"mat-error\">\n          {{ widgetInstance.error }}\n        </span>\n        <smart-icon\n          *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n          [icon]=\"widgetInstance.errorIcon\"\n          [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n          matSuffix\n        ></smart-icon>\n        <mat-hint>\n          {{ widgetInstance.dateFormatHint }}\n        </mat-hint>\n      </mat-form-field>\n    </div> -->\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_TIME_PICKER\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div class=\"dateTimePickerContainer\">\n          <mat-form-field\n            class=\"input widgetContent date {{ widgetInstance.cssClass ?? '' }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n            appearance=\"outline\"\n          >\n            <mat-label\n              class=\"label\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n              *ngIf=\"!widgetInstance.showLabel\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}\n            </mat-label>\n            <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n            <mat-datepicker #picker (closed)=\"handleBlurEvent(widgetInstance)\"></mat-datepicker>\n            <input\n              #dateInput\n              matInput\n              [formControlName]=\"widgetInstance.key\"\n              [min]=\"convertToLocalDateTime(widgetInstance.dateFieldProperties?.minDate ?? null)\"\n              [max]=\"convertToLocalDateTime(widgetInstance.dateFieldProperties?.maxDate ?? null)\"\n              [id]=\"widgetInstance.key\"\n              [value]=\"widgetInstance.value\"\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              [matDatepicker]=\"picker\"\n              (blur)=\"onDatePickerBlur($event)\"\n              (dateChange)=\"onValueChange?.next(widgetInstance)\"\n              [matDatepickerFilter]=\"widgetInstance.filter ?? dateFilter\"\n            />\n\n            <smart-icon\n              *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n              [icon]=\"widgetInstance.errorIcon\"\n              [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              matSuffix\n            ></smart-icon>\n            <mat-hint>\n              {{ widgetInstance.dateFormatHint }}\n            </mat-hint>\n          </mat-form-field>\n          <mat-form-field\n            *ngIf=\"hasCreated\"\n            class=\"input widgetContent time\"\n            [ngClass]=\"widgetInstance.cssClass ?? ''\"\n            [ngStyle]=\"{ width: widgetInstance.minWidth + 'px' }\"\n            appearance=\"outline\"\n          >\n            <input\n              #timeInput\n              [formControlName]=\"widgetInstance.key + '-time'\"\n              [id]=\"widgetInstance.key\"\n              [type]=\"'time'\"\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              (blur)=\"onTimePickerBlur($event)\"\n              matInput\n            />\n          </mat-form-field>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.SELECT\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-select\n            [formControlName]=\"widgetInstance.key\"\n            (selectionChange)=\"onValueChange?.next($event.value)\"\n            (closed)=\"handleBlurEvent(widgetInstance)\"\n            [disabled]=\"widgetInstance.isDisabled!\"\n            [compareWith]=\"\n              widgetInstance.compareWith == null ? compareItems : widgetInstance.compareWith\n            \"\n            placeholder=\"{{ widgetInstance.placeholder ? widgetInstance.placeholder : '' }}\"\n          >\n            <div *ngFor=\"let option of widgetInstance.valueList\">\n              <mat-optgroup\n                *ngIf=\"option.type === getType().ITEM_GROUP\"\n                [label]=\"option.label\"\n                [disabled]=\"option.isDisabled\"\n              >\n                <mat-option\n                  *ngFor=\"let innerOption of option.valueList\"\n                  [value]=\"innerOption.value\"\n                  [disabled]=\"innerOption.isDisabled\"\n                >\n                  <smart-icon\n                    *ngIf=\"innerOption.icon\"\n                    [icon]=\"innerOption.icon\"\n                    [color]=\"innerOption.iconColor\"\n                  ></smart-icon>\n                  {{ innerOption.label }}\n                </mat-option>\n              </mat-optgroup>\n              <mat-option\n                *ngIf=\"option.type === getType().ITEM\"\n                [value]=\"option.value\"\n                [disabled]=\"option.isDisabled\"\n              >\n                <smart-icon\n                  *ngIf=\"option.icon\"\n                  [icon]=\"option.icon\"\n                  [color]=\"option.iconColor\"\n                ></smart-icon\n                >{{ option.label }}</mat-option\n              >\n            </div>\n          </mat-select>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n        </mat-form-field>\n        <mat-hint\n          *ngIf=\"\n            !widgetInstance?.hint ||\n            widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n          \"\n          >{{ widgetInstance.hint?.text }}</mat-hint\n        >\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.SELECT_MULTIPLE\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-select\n            [formControlName]=\"widgetInstance.key\"\n            multiple\n            (selectionChange)=\"onValueChange?.next($event.value)\"\n            (closed)=\"handleBlurEvent(widgetInstance)\"\n            [disabled]=\"widgetInstance.isDisabled!\"\n            [compareWith]=\"\n              widgetInstance.compareWith == null ? compareItems : widgetInstance.compareWith\n            \"\n            placeholder=\"{{ widgetInstance.placeholder ? widgetInstance.placeholder : '' }}\"\n          >\n            <div *ngFor=\"let option of widgetInstance.valueList\">\n              <mat-optgroup\n                *ngIf=\"option.type === getType().ITEM_GROUP\"\n                [label]=\"option.label\"\n                [disabled]=\"option.isDisabled\"\n              >\n                <mat-option\n                  *ngFor=\"let innerOption of option.valueList\"\n                  [value]=\"innerOption.value\"\n                  [disabled]=\"innerOption.isDisabled\"\n                >\n                  <smart-icon\n                    *ngIf=\"innerOption.icon\"\n                    [icon]=\"innerOption.icon\"\n                    [color]=\"innerOption.iconColor\"\n                  ></smart-icon\n                  >{{ innerOption.label }}</mat-option\n                >\n              </mat-optgroup>\n              <mat-option\n                *ngIf=\"option.type === getType().ITEM\"\n                [value]=\"option.value\"\n                [disabled]=\"option.isDisabled\"\n              >\n                <smart-icon\n                  *ngIf=\"option.icon\"\n                  [icon]=\"option.icon\"\n                  [color]=\"option.iconColor\"\n                ></smart-icon\n                >{{ option.label }}</mat-option\n              >\n            </div>\n          </mat-select>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n        </mat-form-field>\n        <mat-hint\n          *ngIf=\"\n            !widgetInstance?.hint ||\n            widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n          \"\n          >{{ widgetInstance.hint?.text }}</mat-hint\n        >\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.LABEL\"\n        class=\"label widgetContainer\"\n        [ngStyle]=\"{ width: widgetInstance.minWidth + 'px' }\"\n      >\n        <div class=\"label-title labelContainer\" [ngClass]=\"widgetInstance.cssClass ?? ''\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{ widgetInstance.cssClass ?? '' }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          @if (widgetInstance.widgetDescription) {\n            <p>{{ widgetInstance.widgetDescription }}</p>\n          }\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.TIME\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent time {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <input\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [type]=\"'time'\"\n            [value]=\"getTime()\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            matInput\n            (change)=\"handleBlurEvent(widgetInstance)\"\n          />\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n        </mat-form-field>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.TOGGLE\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div\n          class=\"widgetContent  {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        >\n          <mat-slide-toggle\n            formControlName=\"{{ widgetInstance.key }}\"\n            value=\"{{ widgetInstance.value }}\"\n            (change)=\"onValueChange?.next($event)\"\n            [labelPosition]=\"widgetInstance.toggleLabelPosition ?? 'before'\"\n            >{{ !widgetInstance.showLabel ? widgetInstance.label : '' }}</mat-slide-toggle\n          ><span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n          ></smart-icon>\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.INDICATOR\" class=\"widgetContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"{{ labelColor }} labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div class=\"smartIndicator widgetContent\">\n          <div class=\"indicatorItems {{ widgetInstance.cssClass ?? '' }}\" [ngClass]=\"getNgClass()\">\n            <div\n              *ngFor=\"let item of indicatorItems; let i = index\"\n              class=\"indicatorItem\"\n              [ngClass]=\"getIndicatorItemClass(i)\"\n            ></div>\n          </div>\n          <p [ngClass]=\"getIndicatorStatusLabelColor()\">\n            {{ getIndicatorStatusLabel() }}\n          </p>\n        </div>\n      </div>\n\n      @if (widgetInstance.type === smartFormWidgetType.FILE_UPLOADER) {\n        <div class=\"widgetContainer\">\n          <smart-file-editor\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n            (uploadFilesEvent)=\"upload($event)\"\n          />\n        </div>\n      }\n\n      @if (widgetInstance.type === smartFormWidgetType.MULTI_FILE_UPLOADER) {\n        <div class=\"widgetContainer\">\n          <smart-multi-file-editor\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n            (uploadFilesEvent)=\"upload($event)\"\n            (fileEvent)=\"executeUiAction($event.uiAction)\"\n          />\n        </div>\n      }\n\n      @if (widgetInstance.type === smartFormWidgetType.IMAGE) {\n        <div class=\"widgetContainer imageContainer\">\n          <h4\n            *ngIf=\"widgetInstance.showLabel && getWidgetLabel(widgetInstance)\"\n            class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n\n          @if (widgetInstance.imageProperties?.image) {\n            <smart-icon\n              [imageResource]=\"widgetInstance.imageProperties?.image\"\n              class=\"widgetContent {{ widgetInstance.imageCss ?? '' }}\"\n              alt=\"Image\"\n              title=\"{{ widgetInstance.key }}\"\n              [ngClass]=\"getNgClass()\"\n              [ngStyle]=\"getStyle()\"\n            ></smart-icon>\n          } @else if (widgetInstance.value) {\n            <smart-icon\n              [(ngModel)]=\"widgetInstance.value\"\n              [imageResource]=\"widgetInstance.value\"\n              class=\"widgetContent {{ widgetInstance.imageCss ?? '' }}\"\n              alt=\"Image\"\n              title=\"{{ widgetInstance.key }}\"\n              [ngClass]=\"getNgClass()\"\n              [ngStyle]=\"getStyle()\"\n            ></smart-icon>\n          }\n        </div>\n      }\n\n      @if (widgetInstance.type === smartFormWidgetType.DIV) {\n        <div class=\"widgetContainer\">\n          <div\n            class=\"smartDiv\"\n            [innerHTML]=\"sanitizeHtml(getWidgetLabel(widgetInstance))\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          >\n          </div>\n        </div>\n      }\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.SVG\" class=\"widgetContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div\n          class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [innerHTML]=\"sanitizeHtml(widgetInstance.value)\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        ></div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.DIVIDER\" class=\"widgetContainer\">\n        <hr\n          class=\"smartDivider {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        />\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.BUTTON\" class=\"widgetContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div\n          class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        >\n          <button\n            mat-button\n            [ngClass]=\"getButtonType(widgetInstance.uiActionDescriptor)\"\n            [color]=\"widgetInstance.uiActionDescriptor?.color\"\n            (click)=\"onButtonClicked(widgetInstance)\"\n          >\n            <div\n              *ngIf=\"isOnlyIcon(widgetInstance.uiActionDescriptor); then iconOnly; else text\"\n            ></div>\n            <ng-template #iconOnly>\n              <smart-icon\n                *ngIf=\"widgetInstance.uiActionDescriptor?.icon\"\n                [icon]=\"widgetInstance.uiActionDescriptor!.icon!\"\n                [color]=\"\n                  widgetInstance.uiActionDescriptor?.iconColor ??\n                  widgetInstance.uiActionDescriptor?.color\n                \"\n              ></smart-icon>\n            </ng-template>\n            <ng-template #text>\n              <smart-icon\n                *ngIf=\"\n                  widgetInstance.uiActionDescriptor?.icon &&\n                  widgetInstance.uiActionDescriptor?.iconPosition === 'PRE'\n                \"\n                [icon]=\"widgetInstance.uiActionDescriptor!.icon!\"\n                [color]=\"\n                  widgetInstance.uiActionDescriptor?.iconColor ??\n                  widgetInstance.uiActionDescriptor?.color\n                \"\n              ></smart-icon>\n              {{ widgetInstance.uiActionDescriptor?.title }}\n              <smart-icon\n                *ngIf=\"\n                  widgetInstance.uiActionDescriptor?.icon &&\n                  widgetInstance.uiActionDescriptor?.iconPosition === 'POST'\n                \"\n                [icon]=\"widgetInstance.uiActionDescriptor!.icon!\"\n                [color]=\"\n                  widgetInstance.uiActionDescriptor?.iconColor ??\n                  widgetInstance.uiActionDescriptor?.color\n                \"\n              ></smart-icon>\n            </ng-template>\n          </button>\n        </div>\n      </div>\n\n      <div class=\"widgetContainer\">\n        <h4\n          class=\"labelContainer\"\n          *ngIf=\"widgetInstance.type === smartFormWidgetType.COMPONENT && widgetInstance.showLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div class=\"widgetContent\">\n          <ng-template #customComponent></ng-template>\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.RICH_TEXT\" class=\"widgetContainer\">\n        <div class=\"labelContainer\">\n          <h4 *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div class=\"widgetContent\">\n          <quill-editor\n            #quillEditor\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [modules]=\"widgetInstance.isDisabled ? emptyQuillToolbar : widgetInstance.quillModules\"\n            [placeholder]=\"widgetInstance.placeholder\"\n            [readOnly]=\"widgetInstance.isReadonly\"\n            [maxLength]=\"widgetInstance.maxLength\"\n            (onContentChanged)=\"onRichTextEditorContentChanged($event)\"\n          ></quill-editor>\n          <mat-hint\n            *ngIf=\"\n              !widgetInstance?.hint ||\n              widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n            \"\n            >{{ widgetInstance.hint?.text }}</mat-hint\n          >\n          <mat-hint\n            *ngIf=\"widgetInstance.showCharacterLimitSuffix && widgetInstance.maxLength\"\n            matSuffix\n            align=\"end\"\n            class=\"rich-text-editor-leeway-counter\"\n            >{{ getRichTextEditorLengthLeeway() }}</mat-hint\n          >\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.SORTABLE\" class=\"widgetContainer\">\n        <div class=\"labelContainer\">\n          <h4 *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div class=\"widgetContent\">\n          <lib-sortable-widget\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n          ></lib-sortable-widget>\n        </div>\n      </div>\n    </div>\n    <div *ngIf=\"widgetInstance.type === smartFormWidgetType.MATRIX\" class=\"widgetContainer\">\n      <div class=\"labelContainer\">\n        <h4 *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n          widgetInstance.hint?.text\n        }}</mat-hint>\n      </div>\n\n      <table class=\"matrixTable widgetContent\">\n        <tr>\n          <th></th>\n          <th class=\"optionLabel\" *ngFor=\"let option of widgetInstance.value.columns\">\n            {{ option.displayValue }}\n          </th>\n        </tr>\n        <tr *ngFor=\"let question of widgetInstance.value.rows; let i = index\">\n          <th class=\"questionLabel\">\n            <label>{{ question.displayValue }}</label>\n          </th>\n\n          <td class=\"selectTd\" *ngFor=\"let option of widgetInstance.value.columns; let j = index\">\n            <mat-radio-group\n              *ngIf=\"!widgetInstance.isMultiple\"\n              [formControlName]=\"widgetInstance.key + '.' + question.code\"\n              [name]=\"'q' + i\"\n            >\n              <mat-radio-button [value]=\"option.code\"> </mat-radio-button>\n            </mat-radio-group>\n            <div *ngIf=\"widgetInstance.isMultiple\">\n              <mat-checkbox\n                [formControlName]=\"\n                  widgetInstance.key + '.data.' + question.code + '.' + option.code\n                \"\n                [value]=\"widgetInstance.value['data'][question.code][option.code]\"\n                [checked]=\"true\"\n              ></mat-checkbox>\n            </div>\n          </td>\n          <br />\n          <button *ngIf=\"widgetInstance.button\" mat-icon-button (click)=\"removeMatrixRow(question)\"\n            ><smart-icon icon=\"close\"></smart-icon\n          ></button>\n        </tr>\n      </table>\n    </div>\n    <div *ngIf=\"widgetInstance.type === smartFormWidgetType.YOUTUBE_PLAYER\" class=\"widgetContainer\">\n      <div class=\"labelContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"{{ labelColor }} {{ widgetInstance.cssLabelClass }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n          widgetInstance.hint?.text\n        }}</mat-hint>\n      </div>\n      <youtube-player\n        [ngClass]=\"getNgClass()\"\n        [ngStyle]=\"getStyle()\"\n        videoId=\"{{ widgetInstance.videoId }}\"\n        [width]=\"widgetInstance.width\"\n        [height]=\"widgetInstance.height\"\n        [startSeconds]=\"widgetInstance.startSeconds\"\n        [endSeconds]=\"widgetInstance.endSeconds\"\n      ></youtube-player>\n      <mat-hint\n        *ngIf=\"\n          !widgetInstance?.hint || widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n        \"\n        >{{ widgetInstance.hint?.text }}</mat-hint\n      >\n    </div>\n    <div *ngIf=\"widgetInstance.type === smartFormWidgetType.MONTH_PICKER\" class=\"widgetContainer\">\n      <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n        <h4 class=\"{{ labelColor }} smart-form-widget-label\">\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n          widgetInstance.hint?.text\n        }}</mat-hint>\n      </div>\n      <lib-smart-month-picker\n        [widgetInstance]=\"widgetInstance\"\n        (valueChange)=\"handleYearMonthPicked($event)\"\n      ></lib-smart-month-picker>\n    </div>\n  </div>\n}\n"]}
1038
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartformwidget.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/smartformwidget/smartformwidget.component.ts","../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/smartformwidget/smartformwidget.component.html"],"names":[],"mappings":"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","sourcesContent":["import { COMMA, ENTER } from '@angular/cdk/keycodes';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { UntypedFormControl, UntypedFormGroup, ValidatorFn, Validators } from '@angular/forms';\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatChipInputEvent } from '@angular/material/chips';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { deepEqual } from 'fast-equals';\nimport moment from 'moment';\nimport { ContentChange, QuillEditorComponent, QuillModules } from 'ngx-quill';\nimport { EditorTextChangeEvent } from 'primeng/editor';\nimport { Observable, Subject, distinctUntilChanged, map, startWith, takeUntil } from 'rxjs';\nimport { ComponentFactoryService } from '../../../component-factory-service/projects';\nimport {\n  IconPosition,\n  UiAction,\n  UiActionButtonType,\n  UiActionDescriptor,\n  UiActionUploadDescriptor,\n} from '../../../view-context/api';\nimport { UiActionToolbarComponent } from '../../../view-context/smart-ui-action/ui-action-toolbar.component';\nimport {\n  COMPONENT_LIBRARY,\n  ComponentLibrary,\n} from '../../../view-context/utility/componentLibrary';\nimport { SmartStyleUtility } from '../../../view-context/utility/smart-style-utility';\nimport {\n  SmartFormWidgetDirection,\n  SmartFormWidgetType,\n  SmartWidgetHintPositionEnum,\n} from '../../api/model/models';\nimport { SmartFormService } from '../../services/smartform.service';\nimport {\n  SmartButton,\n  SmartFormWidget,\n  SmartItem,\n  SmartItems,\n  SmartMatrix,\n} from '../../smartform.form-model';\nimport {\n  SmartFormTextFieldButtonIconPosition,\n  SmartValidator,\n  SophisticatedValueChange,\n  Value,\n} from '../../smartform.model';\nimport { SmartFileEditorComponent } from '../components/smart-file-editor/smart-file-editor.component';\nimport { SmartMultiFileEditorComponent } from '../components/smart-multi-file-editor/smart-multi-file-editor.component';\nimport { Message } from 'primeng/api';\nexport class SmartWidgetSettings {\n  public static useUtc = false;\n}\n@Component({\n  selector: 'smartformwidget',\n  templateUrl: './smartformwidget.component.html',\n  styleUrls: ['./smartformwidget.component.css'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SmartformwidgetComponent implements OnInit, OnDestroy, AfterViewInit {\n  private _destroy$: Subject<void> = new Subject();\n\n  hidePassword: boolean = true;\n\n  smartComponent: any;\n\n  errorMessages: Message[] = [];\n\n  @Input() form!: UntypedFormGroup;\n  @Input() widgetInstance!: SmartFormWidget<any>;\n  @Input() onBlur?: Subject<any>;\n  @Input() onValueChange?: Subject<any>;\n  @Input() labelColor?: string;\n  @Input() sophisticatedValueChange!: Subject<SophisticatedValueChange>;\n  @Input() blurSophisticatedValueChange!: Subject<SophisticatedValueChange>;\n\n  @Output() valueCleared = new EventEmitter<{\n    event?: any;\n    key: any;\n  }>();\n\n  smartFormWidgetType = SmartFormWidgetType;\n\n  capsOn: any;\n\n  @ViewChild('chipInput') chipInputChild?: ElementRef<HTMLInputElement>;\n\n  filteredValueList?: Observable<string[] | undefined>;\n\n  hasError: boolean = false;\n  errorKey?: string;\n\n  indicatorItems?: any[];\n  defaultDate?: Date;\n  // customComponent\n  @ViewChild('customComponent', { read: ViewContainerRef })\n  customComponentVcRef?: ViewContainerRef;\n  customComponentRef?: ComponentRef<any>;\n\n  filteredOptions?: Observable<SmartItem<any>[]>;\n  toHighlight: string = '';\n\n  @ViewChild('quillEditor') quill?: QuillEditorComponent;\n\n  isEnterPressed: boolean = false;\n\n  isDatePickerRequired: boolean = false;\n\n  SmartWidgetHintPosition = SmartWidgetHintPositionEnum;\n\n  // toolbar\n  @ViewChild('toolbar') toolbar?: UiActionToolbarComponent;\n\n  @ViewChildren(SmartformwidgetComponent)\n  childrenWidgetsQL?: QueryList<SmartformwidgetComponent>;\n  componentLibrary = ComponentLibrary;\n  emptyQuillToolbar: QuillModules = {\n    toolbar: false,\n  };\n\n  @ViewChild('sb4Textarea') sb4Textarea!: ElementRef<HTMLTextAreaElement>;\n  @ViewChild(SmartFileEditorComponent) fileUploader!: SmartFileEditorComponent;\n  @ViewChild(SmartMultiFileEditorComponent) multiFileUploader?: SmartMultiFileEditorComponent;\n\n  constructor(\n    private service: SmartFormService,\n    private cfService: ComponentFactoryService,\n    private sanitizer: DomSanitizer,\n    @Inject(COMPONENT_LIBRARY) public compLib: ComponentLibrary,\n    public changeDetector: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.CONTAINER &&\n      this.widgetInstance.valueList\n    ) {\n      this.widgetInstance.valueList = this.service.filterWidgetsByVisibility(\n        this.widgetInstance.valueList\n      );\n    }\n    this.form.valueChanges.pipe(takeUntil(this._destroy$)).subscribe(() => {\n      this.getErrorMessage(this.widgetInstance);\n    });\n    this.onBlur?.pipe(takeUntil(this._destroy$)).subscribe(() => {\n      this.getErrorMessage(this.widgetInstance);\n      if (this.compLib === this.componentLibrary.PRIMENG) {\n        this.getControlMessages(this.widgetInstance.key!);\n      }\n    });\n    // handle initial error message from server\n    this.getErrorMessage(this.widgetInstance);\n    // this.getControlMessages(this.widgetInstance.key!);\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.INDICATOR &&\n      this.widgetInstance.indicator\n    ) {\n      if (this.widgetInstance.indicator?.indicatorLength) {\n        this.indicatorItems = new Array<any>(this.widgetInstance.indicator.indicatorLength);\n      }\n      this.form.controls[this.widgetInstance.indicator!.indicateProperty].valueChanges\n        .pipe(takeUntil(this._destroy$))\n        .subscribe((value: any) => {\n          if (this.widgetInstance.type === SmartFormWidgetType.INDICATOR) {\n            this.widgetInstance.indicator!.indicatorValue =\n              this.widgetInstance.indicator!.changeIndicatorStatus(value);\n          }\n        });\n    }\n\n    if (this.widgetInstance.type === SmartFormWidgetType.DATE_PICKER) {\n      if (this.widgetInstance.value) {\n        this.defaultDate = new Date(this.widgetInstance.value);\n      }\n    }\n\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_FIELD &&\n      this.widgetInstance.selection\n    ) {\n      this.filteredOptions = this.onValueChange!.pipe(\n        startWith(''),\n        map((value) => this._filter(value || '')),\n        takeUntil(this._destroy$)\n      );\n    }\n\n    if (this.widgetInstance.type === SmartFormWidgetType.YOUTUBE_PLAYER) {\n      let videoId = this.parseYoutubeUrl(this.widgetInstance.link!);\n      if (videoId) this.widgetInstance.videoId = videoId;\n      const tag = document.createElement('script');\n\n      tag.src = 'https://www.youtube.com/iframe_api';\n      document.body.appendChild(tag);\n    }\n\n    let formControls: string[] = Object.keys(this.form.controls).filter(\n      (key: string) =>\n        key === this.widgetInstance.key || key.startsWith(`${this.widgetInstance.key}.`)\n    );\n\n    formControls.map((key: string) => {\n      this.form.controls[key].valueChanges\n        .pipe(distinctUntilChanged(), takeUntil(this._destroy$))\n        .subscribe((value: string) => {\n          if (\n            this.widgetInstance.type !== SmartFormWidgetType.TEXT_FIELD_CHIPS &&\n            this.widgetInstance.type !== SmartFormWidgetType.TEXT_FIELD_LOOKUP\n          ) {\n            const valueChange: SophisticatedValueChange = {\n              key,\n              value,\n              kind: this.getSophisticatedEventKind(),\n            };\n\n            this.sophisticatedValueChange.next(valueChange);\n          }\n        });\n    });\n  }\n\n  private getSophisticatedEventKind(): 'selection' | 'basic' {\n    return this.widgetInstance.type === SmartFormWidgetType.SELECT ||\n      this.widgetInstance.type === SmartFormWidgetType.SELECT_MULTIPLE ||\n      this.widgetInstance.type === SmartFormWidgetType.RADIO_BUTTON\n      ? 'selection'\n      : 'basic';\n  }\n\n  parseYoutubeUrl(url: string) {\n    url.replace('/shorts/', '/watch?v=');\n\n    var regExp = /^.*((youtu.be\\/)|(v\\/)|(\\/u\\/\\w\\/)|(embed\\/)|(watch\\?))\\??v?=?([^#&?]*).*/;\n    var match = url.match(regExp);\n\n    return match && match[7].length == 11 ? match[7] : false;\n  }\n\n  _hasJustChanged: boolean = false;\n\n  get hasJustChanged(): boolean {\n    return this._hasJustChanged;\n  }\n  set hasJustChanged(hasJustChanged: boolean) {\n    this._hasJustChanged = hasJustChanged;\n    new Promise((resolve) => setTimeout(resolve, 250)).then(() => {\n      this._hasJustChanged = false;\n    });\n  }\n\n  hasCreated: boolean = false;\n\n  @ViewChild('dateInput') dateInputChild?: ElementRef;\n  @ViewChild('timeInput') timeInputChild?: ElementRef;\n\n  onDatePickerBlur(event: any): void {\n    event.stopPropagation();\n\n    this.handleBlurEvent(this.widgetInstance);\n    this.handleDateChanged(this.form.controls[this.widgetInstance.key!].value);\n  }\n\n  onTimePickerBlur(event: any): void {\n    event.stopPropagation();\n\n    this.handleBlurEvent(this.widgetInstance);\n    this.handleTimeChanged(this.form.controls[`${this.widgetInstance.key}-time`].value);\n  }\n\n  ngAfterViewInit(): void {\n    if (this.widgetInstance.type === SmartFormWidgetType.COMPONENT) {\n      this.customComponentRef = this.cfService.createComponent(\n        this.customComponentVcRef!,\n        this.widgetInstance.component,\n        this.widgetInstance.input\n      );\n    }\n    if (this.compLib === this.componentLibrary.MATERIAL) {\n      if (\n        this.widgetInstance.type === SmartFormWidgetType.DATE_TIME_PICKER ||\n        this.widgetInstance.type === SmartFormWidgetType.MONTH_PICKER\n      ) {\n        this.isDatePickerRequired = !!this.widgetInstance.validators?.some(\n          (smartValidator: SmartValidator) => smartValidator.validator === Validators.required\n        );\n\n        let time;\n        if (this.widgetInstance.value) {\n          let date = new Date(this.widgetInstance.value);\n          let hour = SmartWidgetSettings.useUtc ? date.getUTCHours() : date.getHours();\n          let min = SmartWidgetSettings.useUtc ? date.getUTCMinutes() : date.getMinutes();\n          time = String(hour).padStart(2, '0') + ':' + String(min).padStart(2, '0');\n          this.widgetInstance.value = moment(date);\n          const dateFormControl = this.form.controls[this.widgetInstance.key];\n          if (dateFormControl) {\n            dateFormControl.setValue(this.widgetInstance.value);\n          }\n        } else {\n          time = '';\n        }\n\n        let validators: ValidatorFn[] = [];\n        if (this.widgetInstance.validators) {\n          validators = this.widgetInstance.validators?.map((validator: SmartValidator) => {\n            return validator.validator;\n          });\n        }\n\n        const timeFormControl = new UntypedFormControl(time, validators);\n\n        if (this.widgetInstance.isDisabled) {\n          timeFormControl.disable();\n        }\n\n        this.form.addControl(`${this.widgetInstance.key}-time`, timeFormControl);\n\n        this.hasCreated = true;\n\n        this.form.controls[this.widgetInstance.key!].valueChanges\n          .pipe(takeUntil(this._destroy$))\n          .subscribe((_moment: any) => {\n            this.handleDateChanged(_moment);\n          });\n        this.form.controls[`${this.widgetInstance.key}-time`].valueChanges\n          .pipe(takeUntil(this._destroy$))\n          .subscribe((timeValue: string) => {\n            this.handleTimeChanged(timeValue);\n          });\n      }\n    } else {\n      if (this.widgetInstance.type === SmartFormWidgetType.DATE_PICKER) {\n        this.form.controls[this.widgetInstance.key].valueChanges\n          .pipe(takeUntil(this._destroy$))\n          .subscribe((timeValue: string) => {\n            if (timeValue) {\n              this.defaultDate = new Date(timeValue);\n            } else {\n              this.defaultDate = undefined;\n            }\n          });\n      }\n    }\n\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_BOX &&\n      this.compLib === this.componentLibrary.PRIMENG &&\n      this.widgetInstance.textBoxProperties?.maxRows &&\n      this.sb4Textarea\n    ) {\n      var textarea = this.sb4Textarea.nativeElement;\n      var style = getComputedStyle(textarea);\n\n      var maxLines = this.widgetInstance.textBoxProperties.maxRows;\n      var lineHeight = parseInt(style.getPropertyValue('--sb4-textarea-line-height')) || 20;\n\n      var paddingTop = parseFloat(style.paddingTop) || 0;\n      var paddingBottom = parseFloat(style.paddingBottom) || 0;\n\n      var verticalExtras = paddingTop + paddingBottom;\n\n      textarea.style.height = 'auto';\n      textarea.style.maxHeight = `${lineHeight * maxLines + verticalExtras}px`;\n    }\n\n    if (this.widgetInstance.type === SmartFormWidgetType.FILE_UPLOADER && this.fileUploader) {\n      this.toolbar = this.fileUploader.toolbar;\n    }\n\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n      this.multiFileUploader\n    ) {\n      this.toolbar = this.multiFileUploader.toolbar;\n    }\n  }\n\n  handleDateChanged(_moment: any): void {\n    const isDateFocused = document.activeElement === this.dateInputChild?.nativeElement;\n    const isTimeFocused = document.activeElement === this.timeInputChild?.nativeElement;\n    const dateFormControl = this.form.controls[this.widgetInstance.key!];\n    const timeFormControl = this.form.controls[`${this.widgetInstance.key}-time`];\n\n    if (\n      !this.isDatePickerRequired &&\n      timeFormControl.hasValidator(Validators.required) &&\n      !_moment\n    ) {\n      timeFormControl.removeValidators(Validators.required);\n      timeFormControl.setValue('');\n    } else if (\n      !this.isDatePickerRequired &&\n      !timeFormControl.hasValidator(Validators.required) &&\n      _moment\n    ) {\n      timeFormControl.addValidators(Validators.required);\n\n      if (timeFormControl.value === '') {\n        const now = new Date();\n        timeFormControl.setValue(now.getHours() + ':' + now.getMinutes());\n        timeFormControl.markAsUntouched();\n      }\n    }\n\n    if (!_moment || isDateFocused || isTimeFocused) {\n      return;\n    }\n\n    if (this.hasJustChanged) {\n      this.hasJustChanged = false;\n      return;\n    }\n\n    const timeValue = timeFormControl.value || '00:00';\n    this.hasJustChanged = true;\n\n    if (this.widgetInstance.type === SmartFormWidgetType.DATE_TIME_PICKER) {\n      this.setDateFormControl(dateFormControl, _moment, timeValue);\n      this.widgetInstance.value = dateFormControl.value;\n    }\n  }\n\n  handleTimeChanged(timeValue: string): void {\n    const isFocused = document.activeElement === this.timeInputChild?.nativeElement;\n    const dateFormControl = this.form.controls[this.widgetInstance.key!];\n    const timeFormControl = this.form.controls[`${this.widgetInstance.key}-time`];\n\n    if (\n      !this.isDatePickerRequired &&\n      dateFormControl.hasValidator(Validators.required) &&\n      !timeValue\n    ) {\n      dateFormControl.removeValidators(Validators.required);\n      dateFormControl.setValue(dateFormControl.value ?? '');\n    } else if (\n      !this.isDatePickerRequired &&\n      !dateFormControl.hasValidator(Validators.required) &&\n      timeValue\n    ) {\n      dateFormControl.setValidators(Validators.required);\n    }\n\n    if (isFocused) {\n      return;\n    }\n\n    if (this.hasJustChanged) {\n      this.hasJustChanged = false;\n      return;\n    }\n\n    if (!timeValue) {\n      if (timeFormControl.hasValidator(Validators.required)) {\n        timeFormControl.markAsDirty();\n      }\n      return;\n    }\n\n    let _moment = dateFormControl.value;\n\n    if (!_moment) {\n      return;\n    }\n\n    this.hasJustChanged = true;\n    if (this.widgetInstance.type === SmartFormWidgetType.DATE_TIME_PICKER) {\n      this.setDateFormControl(dateFormControl, _moment, timeValue);\n    }\n  }\n\n  private setDateFormControl(dateFormControl: any, _moment: any, timeValue: string) {\n    if (_moment) {\n      let hour = timeValue.substring(0, 2);\n      let min = timeValue.substring(3, 5);\n      _moment.hour(hour);\n      _moment.minute(min);\n      dateFormControl.setValue(_moment);\n    }\n  }\n\n  getTime(): string {\n    if (this.widgetInstance.type === SmartFormWidgetType.DATE_TIME_PICKER) {\n      return this.widgetInstance.value.toISOString().split('T')[1].substring(0, 5);\n    }\n    return '';\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  onKeydown(): void {\n    this.isEnterPressed = true;\n\n    new Promise((resolve) => setTimeout(resolve, 500)).then(() => {\n      this.isEnterPressed = false;\n    });\n  }\n\n  togglePasswordVisibility(event: any): void {\n    if (!this.isEnterPressed) {\n      this.hidePassword = !this.hidePassword;\n    }\n  }\n\n  getNgClass(): { [className: string]: boolean } {\n    return SmartStyleUtility.getNgClasses(this.widgetInstance.style);\n  }\n\n  getStyle(): { [key: string]: string | number } {\n    if (!this.widgetInstance.style) {\n      this.widgetInstance.style = {\n        classesToAdd: [],\n        classesToRemove: [],\n        style: {},\n      };\n    }\n\n    if (!('width' in this.widgetInstance.style.style) && 'minWidth' in this.widgetInstance) {\n      this.widgetInstance.style.style['width'] = `${this.widgetInstance.minWidth}px`;\n    }\n    return SmartStyleUtility.getNgStyles(this.widgetInstance.style);\n  }\n\n  getLabelNgClass(): { [className: string]: boolean } {\n    if ('labelStyle' in this.widgetInstance) {\n      return SmartStyleUtility.getNgClasses(this.widgetInstance.labelStyle);\n    }\n\n    return {};\n  }\n\n  getLabelStyle(): { [key: string]: string | number } {\n    if ('labelStyle' in this.widgetInstance) {\n      return SmartStyleUtility.getNgStyles(this.widgetInstance.labelStyle);\n    }\n\n    return {};\n  }\n\n  /**\n   * Change handler for the potentially present Quill editor, enforcing max length limits if\n   * necessary.\n   *\n   * @param change the {@link ContentChange} the Quill editor emits\n   * @returns {@code void}\n   */\n  onRichTextEditorContentChanged(change: ContentChange): void {\n    if (this.widgetInstance.type !== SmartFormWidgetType.RICH_TEXT) {\n      return;\n    }\n\n    if (!this.widgetInstance.maxLength) {\n      return;\n    }\n\n    // we are permitted a number one greater than the requested: The quill editor contains an\n    // unremovable new-line character at the end of its content.\n    const maxLength: number = this.widgetInstance.maxLength + 1;\n    if (change.text.length <= maxLength) {\n      return;\n    }\n\n    const insertOpCount: number = change.delta.ops?.filter((it) => !!it.insert).length ?? 0;\n    if (insertOpCount > 0) {\n      this.quill?.quillEditor.setContents(change.oldDelta, 'silent');\n    }\n  }\n\n  onPrimeRichTextEditorContentChanged(change: EditorTextChangeEvent): void {\n    if (this.widgetInstance.type !== SmartFormWidgetType.RICH_TEXT) {\n      return;\n    }\n\n    if (!this.widgetInstance.maxLength) {\n      return;\n    }\n    // we are permitted a number one greater than the requested: The quill editor contains an\n    // unremovable new-line character at the end of its content.\n    const maxLength: number = this.widgetInstance.maxLength + 1;\n    if (change.textValue.length <= maxLength) {\n      return;\n    }\n  }\n\n  /**\n   * Calculates the number of remaining user-space characters allowed to be entered into the Quill\n   * editor.\n   *\n   * <p>\n   * The real length of the editor's content may be much longer - as it is persisted as an HTML\n   * document fragment behind the scenes. This method is concerned by the number of characters the\n   * user perceives.\n   *\n   * @returns the {@link number} of remaining permitted characters the user may input, or {@code -1}\n   *          if the leeway is not interpreted in the component's current state\n   */\n  getRichTextEditorLengthLeeway(): number {\n    if (this.widgetInstance.type !== SmartFormWidgetType.RICH_TEXT) {\n      return -1;\n    }\n\n    if (!this.widgetInstance.maxLength) {\n      return -1;\n    }\n\n    // we are permitted a number one greater than the requested: The quill editor contains an\n    // unremovable new-line character at the end of its content.\n    const maxLength: number = this.widgetInstance.maxLength + 1;\n    if (this.quill) {\n      // this is the intended path (user input):\n      return maxLength - this.quill.quillEditor.getText().length;\n    }\n\n    // fallback to the raw HTML content:\n    return maxLength - this.form.controls[this.widgetInstance.key].value.length;\n  }\n\n  addOnBlur = true;\n  readonly separatorKeysCodes = [ENTER, COMMA] as const;\n  readonly emptySeparatorKeysCodes = [] as const;\n\n  add(event: MatChipInputEvent): void {\n    if (this.widgetInstance.type !== SmartFormWidgetType.TEXT_FIELD_CHIPS) {\n      return;\n    }\n\n    const value = (event.value || '').trim();\n    if (this.setTextFieldChipsValue(value)) {\n      const valueChange: SophisticatedValueChange = {\n        key: this.widgetInstance.key,\n        value: this.form.controls[this.widgetInstance.key].value,\n        kind: 'selection',\n      };\n      this.sophisticatedValueChange.next(valueChange);\n    }\n    // Clear the input value\n    event.chipInput!.clear();\n    this.form.controls[this.widgetInstance.key].markAsTouched();\n  }\n\n  remove(value: SmartFormWidget<any>): void {\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_FIELD_CHIPS ||\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_FIELD_LOOKUP\n    ) {\n      const index = this.form.controls[this.widgetInstance.key].value.indexOf(value);\n\n      if (index >= 0) {\n        this.form.controls[this.widgetInstance.key].value.splice(index, 1);\n        this.form.controls[this.widgetInstance.key].updateValueAndValidity();\n        const valueChange: SophisticatedValueChange = {\n          key: this.widgetInstance.key,\n          value: this.form.controls[this.widgetInstance.key].value,\n          kind: 'selection',\n        };\n        this.sophisticatedValueChange.next(valueChange);\n      }\n    }\n  }\n\n  selected(event: MatAutocompleteSelectedEvent, widgetInstance: SmartFormWidget<any>): void {\n    let value = event.option.viewValue;\n    if (this.setTextFieldChipsValue(value)) {\n      if (\n        widgetInstance.type === SmartFormWidgetType.TEXT_FIELD_CHIPS ||\n        widgetInstance.type === SmartFormWidgetType.TEXT_FIELD_LOOKUP\n      ) {\n        const valueChange: SophisticatedValueChange = {\n          key: widgetInstance.key,\n          value: this.form.controls[widgetInstance.key].value,\n          kind: 'selection',\n        };\n        this.sophisticatedValueChange.next(valueChange);\n      }\n    }\n  }\n\n  private setTextFieldChipsValue(value: string): boolean {\n    if (this.widgetInstance.type !== SmartFormWidgetType.TEXT_FIELD_CHIPS) {\n      return false;\n    }\n\n    if (value) {\n      if (\n        (this.widgetInstance.maxValues &&\n          this.widgetInstance.value!.length < this.widgetInstance.maxValues) ||\n        !this.widgetInstance.maxValues\n      ) {\n        if (!this.form.controls[this.widgetInstance.key].value) {\n          let values = new Array<Object>();\n          this.widgetInstance.value = values;\n          this.form.controls[this.widgetInstance.key].setValue(values);\n          this.form.controls[this.widgetInstance.key].updateValueAndValidity();\n        }\n        this.form.controls[this.widgetInstance.key].value.push(value);\n        this.form.controls[this.widgetInstance.key].updateValueAndValidity();\n        return true;\n      }\n    }\n    return false;\n  }\n\n  getDirection(): string {\n    if (\n      this.widgetInstance.type !== SmartFormWidgetType.CONTAINER &&\n      this.widgetInstance.type !== SmartFormWidgetType.CHECK_BOX &&\n      this.widgetInstance.type !== SmartFormWidgetType.RADIO_BUTTON\n    ) {\n      return '';\n    }\n    if (this.widgetInstance.direction === undefined) {\n      return 'direction-row';\n    } else if (this.widgetInstance.direction === SmartFormWidgetDirection.COL) {\n      return 'direction-col';\n    } else {\n      return 'direction-row';\n    }\n  }\n\n  smartFormTextFieldButtonIconPosition(): typeof SmartFormTextFieldButtonIconPosition {\n    return SmartFormTextFieldButtonIconPosition;\n  }\n\n  getType(): typeof SmartFormWidgetType {\n    return SmartFormWidgetType;\n  }\n\n  getWidgetLabel(widget: SmartFormWidget<any>): string {\n    if (widget.type === SmartFormWidgetType.CONTAINER) {\n      return '';\n    }\n    if (widget.label === '') {\n      return widget.label;\n    }\n    let isRequired = false;\n    if (\n      widget.type !== SmartFormWidgetType.LABEL &&\n      widget.type !== SmartFormWidgetType.TIME &&\n      widget.type !== SmartFormWidgetType.INDICATOR &&\n      widget.type !== SmartFormWidgetType.FILE_UPLOADER &&\n      widget.type !== SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n      widget.type !== SmartFormWidgetType.IMAGE &&\n      widget.type !== SmartFormWidgetType.SVG &&\n      widget.type !== SmartFormWidgetType.DIV &&\n      widget.type !== SmartFormWidgetType.DIVIDER &&\n      widget.type !== SmartFormWidgetType.BUTTON &&\n      widget.type !== SmartFormWidgetType.COMPONENT\n    ) {\n      isRequired = widget.validators?.length ? this.fieldIsRequired() && !!widget.showLabel : false;\n    } else if (widget.type === SmartFormWidgetType.LABEL) {\n      isRequired = widget.markAsRequired ? true : false;\n    }\n    return `${widget.label}${isRequired ? ' *' : ''}`;\n  }\n\n  sanitizeHtml(value?: string): SafeHtml | null {\n    let safeValue = value ?? '';\n    return this.sanitizer.bypassSecurityTrustHtml(safeValue);\n  }\n\n  private fieldIsRequired(): boolean {\n    let value = false;\n    if (\n      this.widgetInstance.type !== SmartFormWidgetType.CONTAINER &&\n      this.widgetInstance.type !== SmartFormWidgetType.LABEL &&\n      this.widgetInstance.type !== SmartFormWidgetType.TIME &&\n      this.widgetInstance.type !== SmartFormWidgetType.INDICATOR &&\n      this.widgetInstance.type !== SmartFormWidgetType.FILE_UPLOADER &&\n      this.widgetInstance.type !== SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n      this.widgetInstance.type !== SmartFormWidgetType.IMAGE &&\n      this.widgetInstance.type !== SmartFormWidgetType.SVG &&\n      this.widgetInstance.type !== SmartFormWidgetType.DIV &&\n      this.widgetInstance.type !== SmartFormWidgetType.DIVIDER &&\n      this.widgetInstance.type !== SmartFormWidgetType.BUTTON &&\n      this.widgetInstance.type !== SmartFormWidgetType.COMPONENT &&\n      this.widgetInstance.type !== SmartFormWidgetType.YOUTUBE_PLAYER\n    ) {\n      this.widgetInstance.validators?.forEach((validator: SmartValidator) => {\n        if (validator.validator == Validators.required) value = true;\n      });\n    }\n    return value;\n  }\n\n  public hasCustomError(widget: SmartFormWidget<any>, validator: SmartValidator): boolean {\n    if (\n      widget.type !== SmartFormWidgetType.CONTAINER &&\n      widget.type !== SmartFormWidgetType.LABEL &&\n      widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER\n    ) {\n      if (this.form.controls[widget.key] && this.form.controls[widget.key].errors) {\n        let hasError = Object.keys(this.form.controls[widget.key].errors!).length\n          ? this.form.controls[widget.key]?.dirty ||\n            (this.form.controls[widget.key]?.touched &&\n              validator &&\n              (this.form.controls[widget.key]?.errors)![validator.name])\n          : false;\n        if (\n          (validator && hasError && !this.errorKey) ||\n          (validator && hasError && this.errorKey === validator.name)\n        ) {\n          this.hasError = true;\n          this.errorKey = validator.name;\n        } else if (!hasError && validator && this.errorKey === validator.name) {\n          this.hasError = false;\n          this.errorKey = undefined;\n        } else {\n          hasError = false;\n        }\n        return hasError;\n      }\n    }\n    return false;\n  }\n\n  getErrorMessage(widgetInstance: SmartFormWidget<any>): boolean {\n    let errorMessage: string;\n    let errorIcon: string | undefined;\n    let errorIconColor: string | undefined;\n    let validator: SmartValidator;\n    if (\n      widgetInstance.type !== SmartFormWidgetType.CONTAINER &&\n      widgetInstance.type !== SmartFormWidgetType.LABEL &&\n      widgetInstance.type !== SmartFormWidgetType.INDICATOR &&\n      widgetInstance.type !== SmartFormWidgetType.FILE_UPLOADER &&\n      widgetInstance.type !== SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n      widgetInstance.type !== SmartFormWidgetType.IMAGE &&\n      widgetInstance.type !== SmartFormWidgetType.SVG &&\n      widgetInstance.type !== SmartFormWidgetType.DIV &&\n      widgetInstance.type !== SmartFormWidgetType.DIVIDER &&\n      widgetInstance.type !== SmartFormWidgetType.BUTTON &&\n      widgetInstance.type !== SmartFormWidgetType.COMPONENT &&\n      widgetInstance.type !== SmartFormWidgetType.YOUTUBE_PLAYER\n    ) {\n      if (this.form.controls[widgetInstance.key] && this.form.controls[widgetInstance.key].errors) {\n        if (\n          this.errorKey &&\n          !Object.keys(this.form.controls[widgetInstance.key].errors!).includes(this.errorKey!)\n        ) {\n          this.errorKey = undefined;\n        }\n        for (\n          let index = 0;\n          index < Object.keys(this.form.controls[widgetInstance.key].errors!).length;\n          index++\n        ) {\n          const errorKey = Object.keys(this.form.controls[widgetInstance.key].errors!)[index];\n          let customValidatorOnWidget = widgetInstance.validators?.filter(\n            (validator: SmartValidator) => validator.name === errorKey\n          );\n          if (customValidatorOnWidget && customValidatorOnWidget.length) {\n            errorMessage = customValidatorOnWidget[0].errorMessage!;\n            errorIcon = customValidatorOnWidget[0].icon;\n            errorIconColor = customValidatorOnWidget[0].iconColor;\n            validator = customValidatorOnWidget[0];\n            break;\n          }\n          let customValidatorOnForm = this.service.smartForm?.validators?.filter(\n            (validator: SmartValidator) => validator.name === errorKey\n          );\n          if (customValidatorOnForm && customValidatorOnForm.length) {\n            errorMessage = customValidatorOnForm[0].errorMessage!;\n            validator = customValidatorOnForm[0];\n            break;\n          }\n        }\n      }\n\n      if (this.hasCustomError(widgetInstance, validator!)) {\n        widgetInstance.error = errorMessage!;\n        widgetInstance.errorIcon = errorIcon;\n        widgetInstance.errorIconColor = errorIconColor;\n        return true;\n      }\n\n      if (widgetInstance.serverErrorMessage) {\n        widgetInstance.error = widgetInstance.serverErrorMessage;\n        widgetInstance.errorIcon = widgetInstance.serverErrorIcon;\n        widgetInstance.errorIconColor = widgetInstance.serverErrorColor;\n        return true;\n      }\n\n      widgetInstance.error = undefined;\n    }\n    return false;\n  }\n\n  getIndicatorItemClass(index: number): string {\n    if (this.widgetInstance.type === SmartFormWidgetType.INDICATOR) {\n      if (this.widgetInstance.indicator.indicatorValue >= index) {\n        return `smart-indicator-${index}`;\n      }\n    }\n    return '';\n  }\n\n  getIndicatorStatusLabelColor(): string {\n    if (this.widgetInstance.type !== SmartFormWidgetType.INDICATOR) {\n      return '';\n    }\n    let value = Math.floor(this.widgetInstance.indicator!.indicatorValue);\n    if (value > this.widgetInstance.indicator!.indicatorLength - 1) {\n      return `smart-indicator-label-${this.widgetInstance.indicator!.indicatorLength - 1}`;\n    }\n    return `smart-indicator-label-${value}`;\n  }\n  getIndicatorStatusLabel(): string {\n    if (this.widgetInstance.type !== SmartFormWidgetType.INDICATOR) {\n      return '';\n    }\n    let value = Math.floor(this.widgetInstance.indicator!.indicatorValue);\n    if (value > this.widgetInstance.indicator!.indicatorLength - 1) {\n      return this.widgetInstance.indicator!.indicatorStatusLabels[\n        this.widgetInstance.indicator!.indicatorLength - 1\n      ];\n    }\n    return this.widgetInstance.indicator!.indicatorStatusLabels[value];\n  }\n\n  upload(event: any): void {\n    let type = this.widgetInstance.type;\n\n    if (\n      type !== SmartFormWidgetType.FILE_UPLOADER &&\n      type !== SmartFormWidgetType.MULTI_FILE_UPLOADER\n    ) {\n      return;\n    }\n\n    let params = {\n      ...event.uiAction.params,\n      _files: event.files,\n      param: '_files',\n    };\n    event.uiAction.params = params;\n\n    this.smartComponent.executeUiAction(event.uiAction);\n  }\n\n  executeUiAction(uiAction: UiAction): void {\n    let type = this.widgetInstance.type;\n    if (type !== SmartFormWidgetType.MULTI_FILE_UPLOADER) {\n      return;\n    }\n    this.smartComponent.executeUiAction(uiAction);\n  }\n\n  getButtonType(descriptor: any): string {\n    switch (descriptor.type) {\n      case 'NORMAL':\n        return 'mat-mdc-button';\n      case 'FLAT':\n        return 'mat-mdc-flat-button';\n      case 'RAISED':\n        return 'mat-mdc-raised-button';\n      case 'STROKED':\n        return 'mat-mdc-stroked-button';\n      case 'ICON':\n        return 'mat-mdc-icon-button';\n      case 'MINI_FAB':\n        return 'mat-mdc-mini-fab';\n      case 'FAB':\n        return 'mat-mdc-fab';\n      default:\n        console.log(`Unhandled action button type case: ${descriptor.type}`);\n        return `mat-button`;\n    }\n  }\n\n  isOnlyIcon(descriptor: any): boolean {\n    return (\n      descriptor.type === 'ICON' || descriptor.type === 'MINI_FAB' || descriptor.type === 'FAB'\n    );\n  }\n\n  onButtonClicked(instance: SmartButton): void {\n    if (instance.uiAction) {\n      instance.callback(instance.uiAction);\n    } else {\n      instance.callback(instance.key);\n    }\n  }\n\n  private _filter(value: InputEvent): SmartItem<any>[] {\n    let filterValue = (value.target as HTMLInputElement)?.value;\n    this.toHighlight = filterValue;\n\n    if (!filterValue) {\n      filterValue = '';\n      this.toHighlight = filterValue;\n    }\n    filterValue = filterValue.toLowerCase();\n\n    if (\n      this.widgetInstance.type === SmartFormWidgetType.TEXT_FIELD &&\n      this.widgetInstance.valueList\n    ) {\n      const result: SmartItem<any>[] = filterValue\n        ? this.widgetInstance.valueList.filter((option: SmartItem<any>) =>\n            option.label.toLowerCase().includes(filterValue)\n          )\n        : this.widgetInstance.valueList;\n      if (result.length === 0 && this.widgetInstance.valueList.length !== 0) {\n        // there could be values after the filter operation but we found none:\n        this.widgetInstance.error = this.widgetInstance.filterErrorMessage;\n      } else {\n        // we either found values, or there were no values to begin with:\n        this.widgetInstance.error = undefined;\n      }\n      return result;\n    }\n\n    return [];\n  }\n\n  dateFilter(d: Date | null): boolean {\n    return true;\n  }\n\n  getMatrixDisplayValue(question: Value, key: string) {\n    (this.widgetInstance as SmartMatrix).value[key].find((value: Value) => {\n      if (value.code == question.code) return question.displayValue;\n      else return question.code;\n    });\n  }\n\n  handleYearMonthPicked(yearMonthValue: any) {\n    this.setDateFormControl(this.form.controls[this.widgetInstance.key!], yearMonthValue, '00:00');\n  }\n\n  compareItems(o1: any, o2: any): boolean {\n    function convert(obj: any): any {\n      if (obj && typeof obj === 'string') {\n        return obj.replace(/\\.v[0-9]+$/, '');\n      }\n      return obj;\n    }\n    // calling this.truncateUri didn't work\n    // TODO: use widget.selection.parameter for ignoreUriVersion / strictUriComparison;\n\n    let v1 = convert(o1);\n    let v2 = convert(o2);\n    return deepEqual(v1, v2);\n  }\n\n  truncateUri(uri: any): any {\n    if (uri && typeof uri === 'string') {\n      return uri.replace(/\\.v[0-9]+$/, '');\n    }\n    return uri;\n  }\n\n  removeMatrixRow(question: any): void {\n    console.log(question);\n    (this.widgetInstance as SmartMatrix).button?.callback(this.widgetInstance, question);\n  }\n\n  isToolbarPresent(): boolean {\n    if (\n      this.widgetInstance.type == SmartFormWidgetType.TEXT_FIELD ||\n      this.widgetInstance.type == SmartFormWidgetType.TEXT_FIELD_LOOKUP ||\n      this.widgetInstance.type == SmartFormWidgetType.FILE_UPLOADER ||\n      this.widgetInstance.type == SmartFormWidgetType.MULTI_FILE_UPLOADER\n    ) {\n      return this.widgetInstance.toolbarId !== undefined && this.widgetInstance.toolbarId !== null;\n    }\n    return false;\n  }\n  getChipsValue(value: any): any {\n    if (typeof value === 'object' && !Array.isArray(value) && value !== null) {\n      if ('name' in value) {\n        return value['name'];\n      }\n      if ('displayValue' in value) {\n        return value['displayValue'];\n      }\n    }\n    return value;\n  }\n  getOptions(items: SmartItems<any>[]) {\n    let values: any[] = [];\n    items.map((item) => {\n      if (item.type === SmartFormWidgetType.ITEM_GROUP) {\n        item.valueList.map((value: SmartItem<any>) => {\n          values.push(value);\n        });\n      } else if (item.type === SmartFormWidgetType.ITEM) {\n        values.push(item);\n      }\n    });\n\n    return values;\n  }\n\n  get clearButtonDescriptor(): UiActionDescriptor {\n    return {\n      title: '',\n      color: 'primary',\n      type: UiActionButtonType.RAISED,\n      icon: this.compLib === ComponentLibrary.PRIMENG ? 'times' : 'close',\n      iconPosition: IconPosition.PRE,\n    };\n  }\n\n  clearField(key: string) {\n    this.form.controls[key].setValue('');\n    this.onBlur?.next(this.widgetInstance);\n  }\n\n  onTextareaChange(value: string) {\n    const ta = this.sb4Textarea?.nativeElement;\n    if (!ta) return;\n\n    if (document.activeElement === ta) {\n      return;\n    }\n\n    requestAnimationFrame(() => {\n      ta.style.height = 'auto';\n      ta.style.height = `${ta.scrollHeight}px`;\n    });\n  }\n\n  handleBlurEvent(eventData: any) {\n    this.onBlur?.next(eventData);\n    this.blurSophisticatedValueChange.next({\n      key: this.widgetInstance.key!,\n      kind: this.getSophisticatedEventKind(),\n      value: this.form.value[this.widgetInstance.key!],\n    });\n  }\n\n  dorpdownOpening = true;\n  onDropDownShow() {\n    this.dorpdownOpening = true;\n  }\n  onDropDownInput() {\n    if (this.dorpdownOpening == true) {\n      this.dorpdownOpening = false;\n    }\n  }\n\n  safeDropDownBlur(event: any) {\n    // We do not use the first blur event after the calendar picker opens,\n    // as it \"eats\" the first click\n\n    if (this.dorpdownOpening) {\n      this.dorpdownOpening = false;\n      return;\n    }\n\n    this.handleBlurEvent(event);\n  }\n\n  calendarOpening = false;\n  onCalendarShow() {\n    this.calendarOpening = true;\n  }\n  onCalendarInput() {\n    if (this.calendarOpening == true) {\n      this.calendarOpening = false;\n    }\n  }\n\n  safeCalendarBlur(event: any) {\n    // We do not use the first blur event after the calendar picker opens,\n    // as it \"eats\" the first click\n\n    if (this.calendarOpening) {\n      this.calendarOpening = false;\n      return;\n    }\n\n    this.handleBlurEvent(event);\n  }\n\n  convertToLocalDateTime(value: string | null): Date | null {\n    if (!value) return null;\n\n    let parsed = new Date(value);\n\n    if (isNaN(parsed.getTime())) {\n      console.error('Invalid Date:', value);\n      return null;\n    }\n\n    return new Date(\n      parsed.getFullYear(),\n      parsed.getMonth(),\n      parsed.getDate(),\n      parsed.getHours(),\n      parsed.getMinutes(),\n      parsed.getSeconds()\n    );\n  }\n\n  getControlMessages(controlName: string) {\n    const control = this.form.controls[controlName];\n    const errors = this.form.controls[controlName]?.errors ?? {};\n\n    this.errorMessages = Object.keys(errors)\n      .filter((key) => typeof errors[key] === 'string')\n      .map((key) => ({\n        severity: 'error',\n        detail: errors[key],\n      }));\n\n    if (this.errorMessages.length === 0) {\n      if (\n        this.widgetInstance.type !== SmartFormWidgetType.CONTAINER &&\n        this.widgetInstance.type !== SmartFormWidgetType.LABEL &&\n        this.widgetInstance.type !== SmartFormWidgetType.INDICATOR &&\n        this.widgetInstance.type !== SmartFormWidgetType.FILE_UPLOADER &&\n        this.widgetInstance.type !== SmartFormWidgetType.MULTI_FILE_UPLOADER &&\n        this.widgetInstance.type !== SmartFormWidgetType.IMAGE &&\n        this.widgetInstance.type !== SmartFormWidgetType.SVG &&\n        this.widgetInstance.type !== SmartFormWidgetType.DIV &&\n        this.widgetInstance.type !== SmartFormWidgetType.DIVIDER &&\n        this.widgetInstance.type !== SmartFormWidgetType.BUTTON &&\n        this.widgetInstance.type !== SmartFormWidgetType.COMPONENT &&\n        this.widgetInstance.type !== SmartFormWidgetType.YOUTUBE_PLAYER\n      ) {\n        if (Object.keys(errors).length > 0) {\n          this.errorMessages.push({\n            severity: 'error',\n            detail: this.widgetInstance.serverErrorMessage,\n          });\n        }\n      }\n    }\n  }\n}\n","@if (compLib === componentLibrary.PRIMENG) {\n  <div class=\"container prime\" [formGroup]=\"form\">\n    <div\n      [ngClass]=\"widgetInstance.cssClass ?? ''\"\n      class=\"container\"\n      *ngIf=\"widgetInstance.isVisible === undefined ? true : widgetInstance.isVisible\"\n    >\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CONTAINER\" [ngClass]=\"getDirection()\">\n        <smartformwidget\n          *ngFor=\"let widget of widgetInstance.valueList\"\n          [form]=\"form\"\n          [widgetInstance]=\"widget\"\n          class=\"container-item\"\n          [ngClass]=\"widget.cssClass ?? ''\"\n          [onBlur]=\"onBlur\"\n          [onValueChange]=\"onValueChange\"\n          [sophisticatedValueChange]=\"sophisticatedValueChange\"\n          [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\n          class=\"{{ widget.key }}\"\n          [labelColor]=\"labelColor\"\n        ></smartformwidget>\n      </div>\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer textFieldContainer\">\n          <p-floatLabel [ngClass]=\"{ hasToolbar: isToolbarPresent() }\">\n            <input\n              *ngIf=\"!widgetInstance.mask\"\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              type=\"{{ widgetInstance.isPassword ? (hidePassword ? 'password' : 'text') : '' }}\"\n              pInputText\n              formControlName=\"text\"\n              (change)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n            />\n            <p-inputMask\n              *ngIf=\"widgetInstance.mask\"\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              [mask]=\"widgetInstance.mask\"\n              (onBlur)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n            />\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n          <div class=\"textFieldButtons\">\n            <smart-ui-action-toolbar\n              #toolbar\n              *ngIf=\"isToolbarPresent()\"\n              class=\"textFieldToolbar\"\n              matSuffix\n              [id]=\"widgetInstance.toolbarId\"\n            >\n            </smart-ui-action-toolbar>\n            @if (widgetInstance.textFieldProperties?.clearable) {\n              <ui-action-button\n                class=\"clearButton\"\n                [addBasicClasses]=\"false\"\n                [descriptor]=\"clearButtonDescriptor\"\n                (actionClick)=\"clearField(widgetInstance.key)\"\n              />\n            }\n          </div>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_NUMBER\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-inputNumber\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              inputId=\"minmax\"\n              mode=\"decimal\"\n              [max]=\"widgetInstance.maxValues ?? null\"\n              [minFractionDigits]=\"0\"\n              [maxFractionDigits]=\"5\"\n              (onBlur)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n            />\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.RICH_TEXT\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div class=\"labelContainer\">\n          <div *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </div>\n        </div>\n        <div>\n          <div class=\"widgetContent\">\n            <p-editor\n              [ngClass]=\"widgetInstance.isReadonly == true ? 'disabledEditor' : ''\"\n              [formControlName]=\"widgetInstance.key\"\n              [id]=\"widgetInstance.key\"\n              [modules]=\"\n                widgetInstance.isDisabled ? emptyQuillToolbar : widgetInstance.quillModules\n              \"\n              [placeholder]=\"widgetInstance.placeholder\"\n              [readOnly]=\"widgetInstance.isReadonly\"\n              [disabled]=\"widgetInstance.isReadonly ?? false\"\n              [maxLength]=\"widgetInstance.maxLength\"\n              (onTextChange)=\"onPrimeRichTextEditorContentChanged($event)\"\n              (onTextChange)=\"handleBlurEvent($event)\"\n            />\n          </div>\n          <span class=\"prime-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.SORTABLE\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div class=\"labelContainer\">\n          <h4 *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n        </div>\n        <div class=\"widgetContent\">\n          <lib-sortable-widget\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n          ></lib-sortable-widget>\n        </div>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_PICKER\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-calendar\n              [formControlName]=\"widgetInstance.key\"\n              [iconDisplay]=\"'input'\"\n              [showIcon]=\"true\"\n              [minDate]=\"\n                convertToLocalDateTime(widgetInstance.dateFieldProperties?.minDate ?? null)\n              \"\n              [maxDate]=\"\n                convertToLocalDateTime(widgetInstance.dateFieldProperties?.maxDate ?? null)\n              \"\n              [showClear]=\"true\"\n              (onShow)=\"onCalendarShow()\"\n              (onInput)=\"onCalendarInput()\"\n              (onBlur)=\"safeCalendarBlur($event)\"\n              (onClear)=\"handleBlurEvent($event)\"\n              (onClose)=\"handleBlurEvent($event)\"\n              dateFormat=\"yy-mm-dd\"\n              appendTo=\"body\"\n            />\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_TIME_PICKER\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-calendar\n              [formControlName]=\"widgetInstance.key\"\n              [iconDisplay]=\"'input'\"\n              [showIcon]=\"true\"\n              [showTime]=\"true\"\n              [showClear]=\"true\"\n              [minDate]=\"\n                convertToLocalDateTime(widgetInstance.dateFieldProperties?.minDate ?? null)\n              \"\n              [maxDate]=\"\n                convertToLocalDateTime(widgetInstance.dateFieldProperties?.maxDate ?? null)\n              \"\n              hourFormat=\"24\"\n              (onShow)=\"onCalendarShow()\"\n              (onInput)=\"onCalendarInput()\"\n              (onBlur)=\"safeCalendarBlur($event)\"\n              (onClear)=\"handleBlurEvent($event)\"\n              (onClose)=\"handleBlurEvent($event)\"\n              dateFormat=\"yy-mm-dd\"\n              appendTo=\"body\"\n            >\n            </p-calendar>\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.SELECT\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-dropdown\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              [options]=\"getOptions(widgetInstance.valueList)\"\n              [checkmark]=\"true\"\n              [filter]=\"true\"\n              [showClear]=\"true\"\n              (onBlur)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n              [compareWith]=\"\n                widgetInstance.compareWith == null ? compareItems : widgetInstance.compareWith\n              \"\n              appendTo=\"body\"\n            />\n            <span class=\"prime-error\">\n              {{ widgetInstance.error }}\n            </span>\n            <smart-icon\n              *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n              [icon]=\"widgetInstance.errorIcon\"\n              [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              matSuffix\n            ></smart-icon>\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.SELECT_MULTIPLE\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-multiSelect\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              [options]=\"getOptions(widgetInstance.valueList)\"\n              [checkmark]=\"true\"\n              [showClear]=\"true\"\n              (onPanelShow)=\"onDropDownShow()\"\n              (onBlur)=\"safeDropDownBlur($event)\"\n              (onClear)=\"handleBlurEvent($event)\"\n              (onPanelHide)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n              [compareWith]=\"\n                widgetInstance.compareWith == null ? compareItems : widgetInstance.compareWith\n              \"\n              appendTo=\"body\"\n              selectedItemsLabel=\"{0} elem kiválasztva\"\n            />\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_BOX\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\" [ngClass]=\"getNgClass()\" [ngStyle]=\"getStyle()\">\n          <p-floatLabel>\n            <textarea\n              class=\"sb4-textarea\"\n              #sb4Textarea\n              pInputTextarea\n              [autoResize]=\"true\"\n              cols=\"30\"\n              [rows]=\"widgetInstance.textBoxProperties?.minRows ?? 1\"\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              placeholder=\" \"\n              [id]=\"widgetInstance.key\"\n              (change)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n              (ngModelChange)=\"onTextareaChange($event)\"\n            ></textarea>\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n              [for]=\"widgetInstance.key\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n        </div>\n        <p-messages\n          class=\"floating-error\"\n          *ngIf=\"errorMessages && errorMessages.length\"\n          [value]=\"errorMessages\"\n          [closable]=\"true\"\n        ></p-messages>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_LOOKUP\"\n        class=\"widgetContainer\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <div\n          *ngIf=\"widgetInstance.showLabel && !widgetInstance.isFloatLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </div>\n        <div class=\"widgetContainer\">\n          <p-floatLabel>\n            <p-chips\n              [disabled]=\"widgetInstance.isDisabled ? widgetInstance.isDisabled : false\"\n              [max]=\"0\"\n              [maxLength]=\"0\"\n              [formControlName]=\"widgetInstance.key\"\n              [(ngModel)]=\"widgetInstance.value\"\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              (onBlur)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n            >\n              <ng-template let-item pTemplate=\"item\"> {{ getChipsValue(item) }} </ng-template>\n            </p-chips>\n            <label\n              *ngIf=\"widgetInstance.showLabel && widgetInstance.isFloatLabel\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}</label\n            >\n          </p-floatLabel>\n          <smart-ui-action-toolbar\n            #toolbar\n            *ngIf=\"isToolbarPresent()\"\n            matSuffix\n            [id]=\"widgetInstance.toolbarId\"\n          ></smart-ui-action-toolbar>\n        </div>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.LABEL\"\n        class=\"label widgetContainer\"\n        [ngStyle]=\"{ width: widgetInstance.minWidth + 'px' }\"\n      >\n        <div class=\"label-title labelContainer\" [ngClass]=\"widgetInstance.cssClass ?? ''\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{ widgetInstance.cssClass ?? '' }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          @if (widgetInstance.widgetDescription) {\n            <p>{{ widgetInstance.widgetDescription }}</p>\n          }\n        </div>\n      </div>\n      @if (widgetInstance.type === smartFormWidgetType.FILE_UPLOADER) {\n        <div class=\"widgetContainer\">\n          <smart-file-editor\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n            (uploadFilesEvent)=\"upload($event)\"\n          />\n        </div>\n      }\n\n      @if (widgetInstance.type === smartFormWidgetType.MULTI_FILE_UPLOADER) {\n        <div class=\"widgetContainer\">\n          <smart-multi-file-editor\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n            (uploadFilesEvent)=\"upload($event)\"\n            (fileEvent)=\"executeUiAction($event.uiAction)\"\n          />\n        </div>\n      }\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.IMAGE\"\n        class=\"widgetContainer imageContainer\"\n      >\n        <h4\n          *ngIf=\"widgetInstance.showLabel && getWidgetLabel(widgetInstance)\"\n          class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n\n        @if (widgetInstance.imageProperties?.image) {\n          <smart-icon\n            [imageResource]=\"widgetInstance.imageProperties!.image\"\n            class=\"widgetContent {{ widgetInstance.imageCss ?? '' }}\"\n            alt=\"Image\"\n            title=\"{{ widgetInstance.key }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          ></smart-icon>\n        } @else if (widgetInstance.value) {\n          <smart-icon\n            [imageResource]=\"widgetInstance.value\"\n            class=\"widgetContent {{ widgetInstance.imageCss ?? '' }}\"\n            alt=\"Image\"\n            title=\"{{ widgetInstance.key }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          ></smart-icon>\n        }\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TOGGLE\"\n        class=\"widgetContainer toggle-col\"\n        [ngClass]=\"widgetInstance.labelPositionClass ?? ''\"\n      >\n        <label [ngClass]=\"widgetInstance.cssLabelClass ?? ''\" [for]=\"widgetInstance.key\">\n          {{ getWidgetLabel(widgetInstance) }}\n        </label>\n        <p-inputSwitch\n          formControlName=\"{{ widgetInstance.key }}\"\n          [(ngModel)]=\"widgetInstance.value\"\n          [id]=\"widgetInstance.key\"\n          name=\"{{ getWidgetLabel(widgetInstance) }}\"\n          (onChange)=\"onValueChange?.next($event)\"\n          (onChange)=\"handleBlurEvent($event)\"\n        />\n      </div>\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CHECK_BOX\" class=\"widgetContainer\">\n        <div\n          class=\"input checkbox widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <section class=\"checkbox-section\" [ngClass]=\"getDirection()\">\n            <div class=\"checkbox-item-container\">\n              <p-checkbox\n                class=\"selecatbleObject\"\n                formControlName=\"{{ widgetInstance.key }}\"\n                [binary]=\"true\"\n                [label]=\"widgetInstance.label\"\n              />\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </section>\n        </div>\n      </div>\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CHECK_BOX_2\" class=\"widgetContainer\">\n        <div\n          class=\"input checkbox widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <section class=\"checkbox-section\" [ngClass]=\"getDirection()\">\n            <div\n              class=\"checkbox-item-container\"\n              *ngFor=\"let checkbox of widgetInstance.valueList; let i = index\"\n            >\n              <img\n                *ngIf=\"checkbox.imageUrl\"\n                title=\"{{ widgetInstance.key }}\"\n                class=\"checkbox-item-image\"\n                [src]=\"checkbox.imageUrl\"\n              />\n              <p-checkbox\n                class=\"selecatbleObject\"\n                formControlName=\"{{ widgetInstance.key + '.' + checkbox.key }}\"\n                [ngModel]=\"checkbox.value\"\n                [binary]=\"true\"\n                [label]=\"checkbox.label\"\n              />\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </section>\n        </div>\n      </div>\n\n      @if (widgetInstance.type === smartFormWidgetType.DIV) {\n        <div class=\"widgetContainer\">\n          <div\n            class=\"smartDiv\"\n            [innerHTML]=\"sanitizeHtml(getWidgetLabel(widgetInstance))\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          >\n          </div>\n        </div>\n      }\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.SVG\" class=\"widgetContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div\n          class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [innerHTML]=\"sanitizeHtml(widgetInstance.value)\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        ></div>\n      </div>\n    </div>\n  </div>\n} @else {\n  <div class=\"container material\" [formGroup]=\"form\">\n    <div\n      [ngClass]=\"widgetInstance.cssClass ?? ''\"\n      class=\"container\"\n      *ngIf=\"widgetInstance.isVisible === undefined ? true : widgetInstance.isVisible\"\n    >\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CONTAINER\" [ngClass]=\"getDirection()\">\n        <smartformwidget\n          *ngFor=\"let widget of widgetInstance.valueList\"\n          [form]=\"form\"\n          [widgetInstance]=\"widget\"\n          class=\"container-item\"\n          [ngClass]=\"widget.cssClass ?? ''\"\n          [onBlur]=\"onBlur\"\n          [onValueChange]=\"onValueChange\"\n          [sophisticatedValueChange]=\"sophisticatedValueChange\"\n          class=\"{{ widget.key }}\"\n          [labelColor]=\"labelColor\"\n        ></smartformwidget>\n      </div>\n\n      <div\n        (capsLock)=\"capsOn = $event\"\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input textField widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n\n          <input\n            *ngIf=\"!widgetInstance.selection\"\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [attr.inputmode]=\"\n              widgetInstance.inputMode ? widgetInstance.inputMode.toLocaleLowerCase() : 'text'\n            \"\n            [type]=\"'string'\"\n            [value]=\"widgetInstance.value\"\n            [readonly]=\"widgetInstance.isReadonly\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            matInput\n            (change)=\"handleBlurEvent($event)\"\n            (input)=\"onValueChange?.next($event)\"\n            type=\"{{ widgetInstance.isPassword ? (hidePassword ? 'password' : 'text') : '' }}\"\n            (keydown.enter)=\"onKeydown()\"\n            maxlength=\"{{ widgetInstance.maxLength }}\"\n          />\n          <!-- [mask]=\"widgetInstance.mask ?? ''\" -->\n          <input\n            *ngIf=\"widgetInstance.selection\"\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [type]=\"'string'\"\n            [value]=\"widgetInstance.value\"\n            [readonly]=\"widgetInstance.isReadonly\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            matInput\n            (change)=\"handleBlurEvent($event)\"\n            (input)=\"onValueChange?.next($event)\"\n            type=\"{{ widgetInstance.isPassword ? 'password' : '' }}\"\n            [matAutocomplete]=\"textFieldAuto\"\n            (keydown.enter)=\"onKeydown()\"\n          />\n          <button\n            *ngIf=\"widgetInstance.isPassword\"\n            mat-icon-button\n            matSuffix\n            (click)=\"togglePasswordVisibility($event)\"\n          >\n            <mat-icon>{{ hidePassword ? 'visibility_off' : 'visibility' }}</mat-icon>\n          </button>\n          <mat-autocomplete #textFieldAuto=\"matAutocomplete\">\n            <mat-option *ngFor=\"let option of filteredOptions | async\" [value]=\"option.label\">\n              <span [innerHTML]=\"option.label | highlight: toHighlight\"></span>\n            </mat-option>\n          </mat-autocomplete>\n          <span class=\"mat-error\" *ngIf=\"capsOn && widgetInstance.isPassword\">\n            {{ widgetInstance.capsLockWarning }}\n          </span>\n\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n\n          <span matPrefix>\n            <smart-icon\n              *ngIf=\"capsOn && widgetInstance.isPassword\"\n              [icon]=\"widgetInstance.capsLockWarningIcon ?? 'keyboard_capslock'\"\n              color=\"warn\"\n            ></smart-icon>\n            <smart-icon\n              *ngIf=\"widgetInstance.icon && widgetInstance.iconPosition === 'PRE'\"\n              [icon]=\"widgetInstance.icon\"\n              [color]=\"widgetInstance.iconColor ?? 'primary'\"\n            ></smart-icon>\n            {{ widgetInstance.prefix }}\n          </span>\n          <span matSuffix>\n            {{ widgetInstance.suffix }}\n          </span>\n          <smart-icon\n            *ngIf=\"\n              widgetInstance.icon &&\n              (!widgetInstance.iconPosition || widgetInstance.iconPosition === 'POST')\n            \"\n            [icon]=\"widgetInstance.icon\"\n            [color]=\"widgetInstance.iconColor ?? 'primary'\"\n            matSuffix\n          ></smart-icon>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n          <div class=\"textFieldButtons\">\n            @if (widgetInstance.textFieldProperties?.clearable) {\n              <ui-action-button\n                class=\"clearButton\"\n                [addBasicClasses]=\"false\"\n                [descriptor]=\"clearButtonDescriptor\"\n                (actionClick)=\"clearField(widgetInstance.key)\"\n              />\n            }\n          </div>\n          <smart-ui-action-toolbar\n            #toolbar\n            *ngIf=\"isToolbarPresent()\"\n            class=\"textFieldToolbar\"\n            matSuffix\n            [id]=\"widgetInstance.toolbarId\"\n          ></smart-ui-action-toolbar>\n          <button\n            *ngIf=\"widgetInstance.textFieldButton\"\n            matSuffix\n            mat-button\n            color=\"{{ widgetInstance.textFieldButton.color }}\"\n            (click)=\"widgetInstance.textFieldButton.callback(widgetInstance)\"\n          >\n            <smart-icon\n              *ngIf=\"\n                widgetInstance.textFieldButton.iconPosition ===\n                  smartFormTextFieldButtonIconPosition().PRE && widgetInstance.textFieldButton.icon\n              \"\n              [icon]=\"widgetInstance.textFieldButton.icon\"\n              [color]=\"widgetInstance.textFieldButton.iconColor\"\n            >\n            </smart-icon>\n            {{ widgetInstance.textFieldButton.label }}\n            <smart-icon\n              *ngIf=\"\n                widgetInstance.textFieldButton.iconPosition ===\n                  smartFormTextFieldButtonIconPosition().POST && widgetInstance.textFieldButton.icon\n              \"\n              [icon]=\"widgetInstance.textFieldButton.icon\"\n            >\n            </smart-icon>\n          </button>\n          <mat-hint\n            *ngIf=\"widgetInstance.showCharacterLimitSuffix && widgetInstance.maxLength\"\n            matSuffix\n            align=\"end\"\n            >{{\n              widgetInstance.maxLength - form.controls[widgetInstance.key].value.length\n            }}</mat-hint\n          >\n        </mat-form-field>\n        <mat-hint\n          *ngIf=\"\n            !widgetInstance?.hint ||\n            widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n          \"\n          >{{ widgetInstance.hint?.text }}</mat-hint\n        >\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_NUMBER\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input textField widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <input\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [value]=\"widgetInstance.value\"\n            [readonly]=\"widgetInstance.isReadonly\"\n            [type]=\"'number'\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            [min]=\"widgetInstance.minValues ?? null\"\n            [max]=\"widgetInstance.maxValues ?? null\"\n            matInput\n            (change)=\"handleBlurEvent($event)\"\n            (input)=\"onValueChange?.next($event)\"\n          />\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <span matPrefix>\n            {{ widgetInstance.prefix }}\n          </span>\n          <span matSuffix>\n            {{ widgetInstance.suffix }}\n          </span>\n          <smart-icon *ngIf=\"widgetInstance.icon\" [icon]=\"widgetInstance.icon\" matSuffix>\n          </smart-icon>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n          <button\n            *ngIf=\"widgetInstance.textFieldButton\"\n            matSuffix\n            mat-button\n            color=\"{{ widgetInstance.textFieldButton.color }}\"\n            (click)=\"widgetInstance.textFieldButton.callback(widgetInstance)\"\n          >\n            <smart-icon\n              *ngIf=\"\n                widgetInstance.textFieldButton.iconPosition ===\n                  smartFormTextFieldButtonIconPosition().PRE && widgetInstance.textFieldButton.icon\n              \"\n              [icon]=\"widgetInstance.textFieldButton.icon\"\n            >\n            </smart-icon>\n            {{ widgetInstance.textFieldButton.label }}\n            <smart-icon\n              *ngIf=\"\n                widgetInstance.textFieldButton.iconPosition ===\n                  smartFormTextFieldButtonIconPosition().POST && widgetInstance.textFieldButton.icon\n              \"\n              [icon]=\"widgetInstance.textFieldButton.icon\"\n            >\n            </smart-icon>\n          </button>\n        </mat-form-field>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_CHIPS\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-chip-grid #chipList aria-label=\"{{ widgetInstance.label }}\">\n            <mat-chip-row\n              [disabled]=\"widgetInstance.isDisabled\"\n              *ngFor=\"let value of widgetInstance.value\"\n              (removed)=\"remove(value)\"\n            >\n              {{ value }}\n              <button matChipRemove>\n                <mat-icon>cancel</mat-icon>\n              </button>\n            </mat-chip-row>\n            <input\n              #chipInput\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              [matChipInputFor]=\"chipList\"\n              [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\n              [matChipInputAddOnBlur]=\"addOnBlur\"\n              [readonly]=\"widgetInstance.isReadonly\"\n              [matAutocomplete]=\"chipAuto\"\n              (matChipInputTokenEnd)=\"add($event)\"\n              (change)=\"handleBlurEvent($event)\"\n              (input)=\"onValueChange?.next($event)\"\n              [disabled]=\"widgetInstance.isDisabled\"\n            />\n            <mat-autocomplete\n              #chipAuto=\"matAutocomplete\"\n              (optionSelected)=\"selected($event, widgetInstance)\"\n            >\n              <mat-option\n                [disabled]=\"widgetInstance.isDisabled\"\n                *ngFor=\"let item of widgetInstance.valueList\"\n                [value]=\"item.value\"\n              >\n                {{ item.label }}\n              </mat-option>\n            </mat-autocomplete>\n          </mat-chip-grid>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n        </mat-form-field>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_FIELD_LOOKUP\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-chip-grid #chipListLookup aria-label=\"{{ widgetInstance.label }}\">\n            <mat-chip\n              [disabled]=\"widgetInstance.isDisabled\"\n              *ngFor=\"let value of widgetInstance.value\"\n              (removed)=\"remove(value)\"\n            >\n              {{ getChipsValue(value) }}\n              <button matChipRemove>\n                <mat-icon>cancel</mat-icon>\n              </button>\n            </mat-chip>\n            <input\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              [matChipInputFor]=\"chipListLookup\"\n              [matChipInputSeparatorKeyCodes]=\"emptySeparatorKeysCodes\"\n              [matChipInputAddOnBlur]=\"false\"\n              [readonly]=\"true\"\n              [disabled]=\"widgetInstance.isDisabled\"\n            />\n          </mat-chip-grid>\n          <smart-ui-action-toolbar\n            #toolbar\n            *ngIf=\"isToolbarPresent()\"\n            matSuffix\n            [id]=\"widgetInstance.toolbarId\"\n          ></smart-ui-action-toolbar>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n        </mat-form-field>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.TEXT_BOX\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <textarea\n            class=\"sb4-textarea\"\n            #sb4Textarea\n            cols=\"30\"\n            cdkTextareaAutosize\n            [cdkAutosizeMinRows]=\"widgetInstance.textBoxProperties?.minRows ?? 1\"\n            [cdkAutosizeMaxRows]=\"widgetInstance.textBoxProperties?.maxRows ?? undefined\"\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [type]=\"'string'\"\n            [value]=\"widgetInstance.value\"\n            [readonly]=\"widgetInstance.isReadonly\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            matInput\n            (change)=\"handleBlurEvent($event)\"\n            maxlength=\"{{ widgetInstance.maxLength }}\"\n          ></textarea>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n          <mat-hint\n            *ngIf=\"widgetInstance.showCharacterLimitSuffix && widgetInstance.maxLength\"\n            matSuffix\n            align=\"end\"\n            >{{\n              widgetInstance.maxLength - form.controls[widgetInstance.key].value.length\n            }}</mat-hint\n          >\n        </mat-form-field>\n        <mat-hint\n          *ngIf=\"\n            !widgetInstance.hint || widgetInstance.hint?.position === SmartWidgetHintPosition.INPUT\n          \"\n          >{{ widgetInstance.hint?.text }}</mat-hint\n        >\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CHECK_BOX\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div\n          class=\"input checkbox widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label class=\"radioLabel\" *ngIf=\"!widgetInstance.showLabel\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <section class=\"checkbox-section\" [ngClass]=\"getDirection()\">\n            <div class=\"checkbox-item-container\">\n              <mat-checkbox\n                class=\"selecatbleObject\"\n                formControlName=\"{{ widgetInstance.key }}\"\n                (change)=\"onValueChange?.next(widgetInstance)\"\n              >\n                {{ widgetInstance.label }}\n              </mat-checkbox>\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </section>\n        </div>\n      </div>\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.CHECK_BOX_2\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{ widgetInstance.cssLabelClass }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div\n          class=\"input checkbox widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label class=\"radioLabel\" *ngIf=\"!widgetInstance.showLabel\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <section class=\"checkbox-section\" [ngClass]=\"getDirection()\">\n            <div\n              class=\"checkbox-item-container\"\n              *ngFor=\"let checkbox of widgetInstance.valueList; let i = index\"\n            >\n              <img\n                *ngIf=\"checkbox.imageUrl\"\n                title=\"{{ widgetInstance.key }}\"\n                class=\"checkbox-item-image\"\n                [src]=\"checkbox.imageUrl\"\n              />\n              <mat-checkbox\n                class=\"selecatbleObject\"\n                formControlName=\"{{ widgetInstance.key + '.' + checkbox.key }}\"\n                [value]=\"checkbox.value\"\n                (change)=\"onValueChange?.next(checkbox)\"\n                [disabled]=\"widgetInstance.isDisabled!\"\n              >\n                {{ checkbox.label }}\n              </mat-checkbox>\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </section>\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.RADIO_BUTTON\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{ widgetInstance.cssLabelClass }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-radio-group\n          class=\"input radio-section widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          aria-label=\"{{ widgetInstance.label }}\"\n          appearance=\"outline\"\n          formControlName=\"{{ widgetInstance.key }}\"\n        >\n          <mat-label class=\"radioLabel\" *ngIf=\"!widgetInstance.showLabel\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <div [ngClass]=\"getDirection()\">\n            <div class=\"radio-item-container\" *ngFor=\"let radio of widgetInstance.valueList\">\n              <img\n                *ngIf=\"radio.imageUrl\"\n                title=\"{{ widgetInstance.key }}\"\n                class=\"radio-item-image\"\n                [src]=\"radio.imageUrl\"\n              />\n              <mat-radio-button\n                class=\"selecatbleObject\"\n                value=\"{{ radio.value }}\"\n                [ngClass]=\"getDirection()\"\n                (change)=\"onValueChange?.next(radio.value)\"\n                [disabled]=\"widgetInstance.isDisabled\"\n              >\n                {{ radio.label }}\n              </mat-radio-button>\n            </div>\n            <div class=\"radio-error\">\n              <span class=\"mat-error\">\n                {{ widgetInstance.error }}\n              </span>\n              <smart-icon\n                *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n                [icon]=\"widgetInstance.errorIcon\"\n                [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              ></smart-icon>\n            </div>\n          </div>\n        </mat-radio-group>\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_PICKER\"\n        class=\"datePicker widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent date {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n          <mat-datepicker #picker (closed)=\"handleBlurEvent(widgetInstance)\"></mat-datepicker>\n          <input\n            matInput\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [value]=\"widgetInstance.value\"\n            [min]=\"convertToLocalDateTime(widgetInstance.dateFieldProperties?.minDate ?? null)\"\n            [max]=\"convertToLocalDateTime(widgetInstance.dateFieldProperties?.maxDate ?? null)\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            [matDatepicker]=\"picker\"\n            (change)=\"handleBlurEvent(widgetInstance)\"\n            (dateChange)=\"onValueChange?.next(widgetInstance)\"\n            [matDatepickerFilter]=\"widgetInstance.filter ?? dateFilter\"\n          />\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n          <mat-hint>\n            {{ widgetInstance.dateFormatHint }}\n          </mat-hint>\n        </mat-form-field>\n      </div>\n\n      <!-- <div\n      *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_TIME_PICKER\"\n      class=\"widgetContainer\"\n    >\n      <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n        <h4 class=\"{{ labelColor }} smart-form-widget-label\">\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n      </div>\n      <mat-form-field\n        class=\"input widgetContent\"\n        [ngClass]=\"widgetInstance.cssClass ?? ''\"\n        [ngStyle]=\"{ width: widgetInstance.minWidth + 'px' }\"\n        appearance=\"outline\"\n      >\n        <mat-label\n          class=\"label\"\n          [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n          *ngIf=\"!widgetInstance.showLabel\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </mat-label>\n        <mat-datepicker-toggle matSuffix [for]=\"$any(picker)\"></mat-datepicker-toggle>\n        <ngx-mat-datetime-picker\n          #picker\n          [showSpinners]=\"true\"\n          [showSeconds]=\"false\"\n          [stepHour]=\"1\"\n          [stepMinute]=\"1\"\n          [stepSecond]=\"10\"\n          [touchUi]=\"false\"\n          [color]=\"'primary'\"\n          [enableMeridian]=\"false\"\n          [disableMinute]=\"false\"\n          [hideTime]=\"false\"\n        >\n        </ngx-mat-datetime-picker>\n        <input\n          matInput\n          [formControlName]=\"widgetInstance.key\"\n          [id]=\"widgetInstance.key\"\n          [value]=\"widgetInstance.value\"\n          placeholder=\"{{ widgetInstance.placeholder }}\"\n          [ngxMatDatetimePicker]=\"picker\"\n          [ngxMatDatetimePickerFilter]=\"widgetInstance.filter ?? dateFilter\"\n          (blur)=\"onBlur?.next(widgetInstance)\"\n        />\n        <span class=\"mat-error\">\n          {{ widgetInstance.error }}\n        </span>\n        <smart-icon\n          *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n          [icon]=\"widgetInstance.errorIcon\"\n          [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n          matSuffix\n        ></smart-icon>\n        <mat-hint>\n          {{ widgetInstance.dateFormatHint }}\n        </mat-hint>\n      </mat-form-field>\n    </div> -->\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.DATE_TIME_PICKER\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div class=\"dateTimePickerContainer\">\n          <mat-form-field\n            class=\"input widgetContent date {{ widgetInstance.cssClass ?? '' }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n            appearance=\"outline\"\n          >\n            <mat-label\n              class=\"label\"\n              [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n              *ngIf=\"!widgetInstance.showLabel\"\n            >\n              {{ getWidgetLabel(widgetInstance) }}\n            </mat-label>\n            <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n            <mat-datepicker #picker (closed)=\"handleBlurEvent(widgetInstance)\"></mat-datepicker>\n            <input\n              #dateInput\n              matInput\n              [formControlName]=\"widgetInstance.key\"\n              [min]=\"convertToLocalDateTime(widgetInstance.dateFieldProperties?.minDate ?? null)\"\n              [max]=\"convertToLocalDateTime(widgetInstance.dateFieldProperties?.maxDate ?? null)\"\n              [id]=\"widgetInstance.key\"\n              [value]=\"widgetInstance.value\"\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              [matDatepicker]=\"picker\"\n              (blur)=\"onDatePickerBlur($event)\"\n              (dateChange)=\"onValueChange?.next(widgetInstance)\"\n              [matDatepickerFilter]=\"widgetInstance.filter ?? dateFilter\"\n            />\n\n            <smart-icon\n              *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n              [icon]=\"widgetInstance.errorIcon\"\n              [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n              matSuffix\n            ></smart-icon>\n            <mat-hint>\n              {{ widgetInstance.dateFormatHint }}\n            </mat-hint>\n          </mat-form-field>\n          <mat-form-field\n            *ngIf=\"hasCreated\"\n            class=\"input widgetContent time\"\n            [ngClass]=\"widgetInstance.cssClass ?? ''\"\n            [ngStyle]=\"{ width: widgetInstance.minWidth + 'px' }\"\n            appearance=\"outline\"\n          >\n            <input\n              #timeInput\n              [formControlName]=\"widgetInstance.key + '-time'\"\n              [id]=\"widgetInstance.key\"\n              [type]=\"'time'\"\n              placeholder=\"{{ widgetInstance.placeholder }}\"\n              (blur)=\"onTimePickerBlur($event)\"\n              matInput\n            />\n          </mat-form-field>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.SELECT\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-select\n            [formControlName]=\"widgetInstance.key\"\n            (selectionChange)=\"onValueChange?.next($event.value)\"\n            (closed)=\"handleBlurEvent(widgetInstance)\"\n            [disabled]=\"widgetInstance.isDisabled!\"\n            [compareWith]=\"\n              widgetInstance.compareWith == null ? compareItems : widgetInstance.compareWith\n            \"\n            placeholder=\"{{ widgetInstance.placeholder ? widgetInstance.placeholder : '' }}\"\n          >\n            <div *ngFor=\"let option of widgetInstance.valueList\">\n              <mat-optgroup\n                *ngIf=\"option.type === getType().ITEM_GROUP\"\n                [label]=\"option.label\"\n                [disabled]=\"option.isDisabled\"\n              >\n                <mat-option\n                  *ngFor=\"let innerOption of option.valueList\"\n                  [value]=\"innerOption.value\"\n                  [disabled]=\"innerOption.isDisabled\"\n                >\n                  <smart-icon\n                    *ngIf=\"innerOption.icon\"\n                    [icon]=\"innerOption.icon\"\n                    [color]=\"innerOption.iconColor\"\n                  ></smart-icon>\n                  {{ innerOption.label }}\n                </mat-option>\n              </mat-optgroup>\n              <mat-option\n                *ngIf=\"option.type === getType().ITEM\"\n                [value]=\"option.value\"\n                [disabled]=\"option.isDisabled\"\n              >\n                <smart-icon\n                  *ngIf=\"option.icon\"\n                  [icon]=\"option.icon\"\n                  [color]=\"option.iconColor\"\n                ></smart-icon\n                >{{ option.label }}</mat-option\n              >\n            </div>\n          </mat-select>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n        </mat-form-field>\n        <mat-hint\n          *ngIf=\"\n            !widgetInstance?.hint ||\n            widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n          \"\n          >{{ widgetInstance.hint?.text }}</mat-hint\n        >\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.SELECT_MULTIPLE\"\n        class=\"widgetContainer\"\n      >\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <mat-select\n            [formControlName]=\"widgetInstance.key\"\n            multiple\n            (selectionChange)=\"onValueChange?.next($event.value)\"\n            (closed)=\"handleBlurEvent(widgetInstance)\"\n            [disabled]=\"widgetInstance.isDisabled!\"\n            [compareWith]=\"\n              widgetInstance.compareWith == null ? compareItems : widgetInstance.compareWith\n            \"\n            placeholder=\"{{ widgetInstance.placeholder ? widgetInstance.placeholder : '' }}\"\n          >\n            <div *ngFor=\"let option of widgetInstance.valueList\">\n              <mat-optgroup\n                *ngIf=\"option.type === getType().ITEM_GROUP\"\n                [label]=\"option.label\"\n                [disabled]=\"option.isDisabled\"\n              >\n                <mat-option\n                  *ngFor=\"let innerOption of option.valueList\"\n                  [value]=\"innerOption.value\"\n                  [disabled]=\"innerOption.isDisabled\"\n                >\n                  <smart-icon\n                    *ngIf=\"innerOption.icon\"\n                    [icon]=\"innerOption.icon\"\n                    [color]=\"innerOption.iconColor\"\n                  ></smart-icon\n                  >{{ innerOption.label }}</mat-option\n                >\n              </mat-optgroup>\n              <mat-option\n                *ngIf=\"option.type === getType().ITEM\"\n                [value]=\"option.value\"\n                [disabled]=\"option.isDisabled\"\n              >\n                <smart-icon\n                  *ngIf=\"option.icon\"\n                  [icon]=\"option.icon\"\n                  [color]=\"option.iconColor\"\n                ></smart-icon\n                >{{ option.label }}</mat-option\n              >\n            </div>\n          </mat-select>\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n        </mat-form-field>\n        <mat-hint\n          *ngIf=\"\n            !widgetInstance?.hint ||\n            widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n          \"\n          >{{ widgetInstance.hint?.text }}</mat-hint\n        >\n      </div>\n\n      <div\n        *ngIf=\"widgetInstance.type === smartFormWidgetType.LABEL\"\n        class=\"label widgetContainer\"\n        [ngStyle]=\"{ width: widgetInstance.minWidth + 'px' }\"\n      >\n        <div class=\"label-title labelContainer\" [ngClass]=\"widgetInstance.cssClass ?? ''\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{ widgetInstance.cssClass ?? '' }}\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          @if (widgetInstance.widgetDescription) {\n            <p>{{ widgetInstance.widgetDescription }}</p>\n          }\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.TIME\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <mat-form-field\n          class=\"input widgetContent time {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n          appearance=\"outline\"\n        >\n          <mat-label\n            class=\"label\"\n            [ngClass]=\"widgetInstance.cssLabelClass ?? ''\"\n            *ngIf=\"!widgetInstance.showLabel\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </mat-label>\n          <input\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [type]=\"'time'\"\n            [value]=\"getTime()\"\n            placeholder=\"{{ widgetInstance.placeholder }}\"\n            matInput\n            (change)=\"handleBlurEvent(widgetInstance)\"\n          />\n          <span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n            matSuffix\n          ></smart-icon>\n        </mat-form-field>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.TOGGLE\" class=\"widgetContainer\">\n        <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n          <h4\n            class=\"{{ labelColor }} smart-form-widget-label {{\n              widgetInstance.cssLabelClass ?? ''\n            }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div\n          class=\"widgetContent  {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        >\n          <mat-slide-toggle\n            formControlName=\"{{ widgetInstance.key }}\"\n            value=\"{{ widgetInstance.value }}\"\n            (change)=\"onValueChange?.next($event)\"\n            [labelPosition]=\"widgetInstance.toggleLabelPosition ?? 'before'\"\n            >{{ !widgetInstance.showLabel ? widgetInstance.label : '' }}</mat-slide-toggle\n          ><span class=\"mat-error\">\n            {{ widgetInstance.error }}\n          </span>\n          <smart-icon\n            *ngIf=\"widgetInstance.error && widgetInstance.errorIcon\"\n            [icon]=\"widgetInstance.errorIcon\"\n            [color]=\"widgetInstance.errorIconColor ?? 'warn'\"\n          ></smart-icon>\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.INDICATOR\" class=\"widgetContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"{{ labelColor }} labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div class=\"smartIndicator widgetContent\">\n          <div class=\"indicatorItems {{ widgetInstance.cssClass ?? '' }}\" [ngClass]=\"getNgClass()\">\n            <div\n              *ngFor=\"let item of indicatorItems; let i = index\"\n              class=\"indicatorItem\"\n              [ngClass]=\"getIndicatorItemClass(i)\"\n            ></div>\n          </div>\n          <p [ngClass]=\"getIndicatorStatusLabelColor()\">\n            {{ getIndicatorStatusLabel() }}\n          </p>\n        </div>\n      </div>\n\n      @if (widgetInstance.type === smartFormWidgetType.FILE_UPLOADER) {\n        <div class=\"widgetContainer\">\n          <smart-file-editor\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n            (uploadFilesEvent)=\"upload($event)\"\n          />\n        </div>\n      }\n\n      @if (widgetInstance.type === smartFormWidgetType.MULTI_FILE_UPLOADER) {\n        <div class=\"widgetContainer\">\n          <smart-multi-file-editor\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n            (uploadFilesEvent)=\"upload($event)\"\n            (fileEvent)=\"executeUiAction($event.uiAction)\"\n          />\n        </div>\n      }\n\n      @if (widgetInstance.type === smartFormWidgetType.IMAGE) {\n        <div class=\"widgetContainer imageContainer\">\n          <h4\n            *ngIf=\"widgetInstance.showLabel && getWidgetLabel(widgetInstance)\"\n            class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n            [ngClass]=\"getLabelNgClass()\"\n            [ngStyle]=\"getLabelStyle()\"\n          >\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n\n          @if (widgetInstance.imageProperties?.image) {\n            <smart-icon\n              [imageResource]=\"widgetInstance.imageProperties?.image\"\n              class=\"widgetContent {{ widgetInstance.imageCss ?? '' }}\"\n              alt=\"Image\"\n              title=\"{{ widgetInstance.key }}\"\n              [ngClass]=\"getNgClass()\"\n              [ngStyle]=\"getStyle()\"\n            ></smart-icon>\n          } @else if (widgetInstance.value) {\n            <smart-icon\n              [(ngModel)]=\"widgetInstance.value\"\n              [imageResource]=\"widgetInstance.value\"\n              class=\"widgetContent {{ widgetInstance.imageCss ?? '' }}\"\n              alt=\"Image\"\n              title=\"{{ widgetInstance.key }}\"\n              [ngClass]=\"getNgClass()\"\n              [ngStyle]=\"getStyle()\"\n            ></smart-icon>\n          }\n        </div>\n      }\n\n      @if (widgetInstance.type === smartFormWidgetType.DIV) {\n        <div class=\"widgetContainer\">\n          <div\n            class=\"smartDiv\"\n            [innerHTML]=\"sanitizeHtml(getWidgetLabel(widgetInstance))\"\n            [ngClass]=\"getNgClass()\"\n            [ngStyle]=\"getStyle()\"\n          >\n          </div>\n        </div>\n      }\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.SVG\" class=\"widgetContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div\n          class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [innerHTML]=\"sanitizeHtml(widgetInstance.value)\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        ></div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.DIVIDER\" class=\"widgetContainer\">\n        <hr\n          class=\"smartDivider {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        />\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.BUTTON\" class=\"widgetContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"labelContainer {{ labelColor }} {{ widgetInstance.cssLabelClass ?? '' }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div\n          class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\n          [ngClass]=\"getNgClass()\"\n          [ngStyle]=\"getStyle()\"\n        >\n          <button\n            mat-button\n            [ngClass]=\"getButtonType(widgetInstance.uiActionDescriptor)\"\n            [color]=\"widgetInstance.uiActionDescriptor?.color\"\n            (click)=\"onButtonClicked(widgetInstance)\"\n          >\n            <div\n              *ngIf=\"isOnlyIcon(widgetInstance.uiActionDescriptor); then iconOnly; else text\"\n            ></div>\n            <ng-template #iconOnly>\n              <smart-icon\n                *ngIf=\"widgetInstance.uiActionDescriptor?.icon\"\n                [icon]=\"widgetInstance.uiActionDescriptor!.icon!\"\n                [color]=\"\n                  widgetInstance.uiActionDescriptor?.iconColor ??\n                  widgetInstance.uiActionDescriptor?.color\n                \"\n              ></smart-icon>\n            </ng-template>\n            <ng-template #text>\n              <smart-icon\n                *ngIf=\"\n                  widgetInstance.uiActionDescriptor?.icon &&\n                  widgetInstance.uiActionDescriptor?.iconPosition === 'PRE'\n                \"\n                [icon]=\"widgetInstance.uiActionDescriptor!.icon!\"\n                [color]=\"\n                  widgetInstance.uiActionDescriptor?.iconColor ??\n                  widgetInstance.uiActionDescriptor?.color\n                \"\n              ></smart-icon>\n              {{ widgetInstance.uiActionDescriptor?.title }}\n              <smart-icon\n                *ngIf=\"\n                  widgetInstance.uiActionDescriptor?.icon &&\n                  widgetInstance.uiActionDescriptor?.iconPosition === 'POST'\n                \"\n                [icon]=\"widgetInstance.uiActionDescriptor!.icon!\"\n                [color]=\"\n                  widgetInstance.uiActionDescriptor?.iconColor ??\n                  widgetInstance.uiActionDescriptor?.color\n                \"\n              ></smart-icon>\n            </ng-template>\n          </button>\n        </div>\n      </div>\n\n      <div class=\"widgetContainer\">\n        <h4\n          class=\"labelContainer\"\n          *ngIf=\"widgetInstance.type === smartFormWidgetType.COMPONENT && widgetInstance.showLabel\"\n          class=\"{{ labelColor }}\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <div class=\"widgetContent\">\n          <ng-template #customComponent></ng-template>\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.RICH_TEXT\" class=\"widgetContainer\">\n        <div class=\"labelContainer\">\n          <h4 *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div class=\"widgetContent\">\n          <quill-editor\n            #quillEditor\n            [formControlName]=\"widgetInstance.key\"\n            [id]=\"widgetInstance.key\"\n            [modules]=\"widgetInstance.isDisabled ? emptyQuillToolbar : widgetInstance.quillModules\"\n            [placeholder]=\"widgetInstance.placeholder\"\n            [readOnly]=\"widgetInstance.isReadonly\"\n            [maxLength]=\"widgetInstance.maxLength\"\n            (onContentChanged)=\"onRichTextEditorContentChanged($event)\"\n          ></quill-editor>\n          <mat-hint\n            *ngIf=\"\n              !widgetInstance?.hint ||\n              widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n            \"\n            >{{ widgetInstance.hint?.text }}</mat-hint\n          >\n          <mat-hint\n            *ngIf=\"widgetInstance.showCharacterLimitSuffix && widgetInstance.maxLength\"\n            matSuffix\n            align=\"end\"\n            class=\"rich-text-editor-leeway-counter\"\n            >{{ getRichTextEditorLengthLeeway() }}</mat-hint\n          >\n        </div>\n      </div>\n\n      <div *ngIf=\"widgetInstance.type === smartFormWidgetType.SORTABLE\" class=\"widgetContainer\">\n        <div class=\"labelContainer\">\n          <h4 *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n            {{ getWidgetLabel(widgetInstance) }}\n          </h4>\n          <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n            widgetInstance.hint?.text\n          }}</mat-hint>\n        </div>\n        <div class=\"widgetContent\">\n          <lib-sortable-widget\n            [formControlName]=\"widgetInstance.key\"\n            [widgetInstance]=\"widgetInstance\"\n          ></lib-sortable-widget>\n        </div>\n      </div>\n    </div>\n    <div *ngIf=\"widgetInstance.type === smartFormWidgetType.MATRIX\" class=\"widgetContainer\">\n      <div class=\"labelContainer\">\n        <h4 *ngIf=\"widgetInstance.showLabel\" class=\"{{ labelColor }}\">\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n          widgetInstance.hint?.text\n        }}</mat-hint>\n      </div>\n\n      <table class=\"matrixTable widgetContent\">\n        <tr>\n          <th></th>\n          <th class=\"optionLabel\" *ngFor=\"let option of widgetInstance.value.columns\">\n            {{ option.displayValue }}\n          </th>\n        </tr>\n        <tr *ngFor=\"let question of widgetInstance.value.rows; let i = index\">\n          <th class=\"questionLabel\">\n            <label>{{ question.displayValue }}</label>\n          </th>\n\n          <td class=\"selectTd\" *ngFor=\"let option of widgetInstance.value.columns; let j = index\">\n            <mat-radio-group\n              *ngIf=\"!widgetInstance.isMultiple\"\n              [formControlName]=\"widgetInstance.key + '.' + question.code\"\n              [name]=\"'q' + i\"\n            >\n              <mat-radio-button [value]=\"option.code\"> </mat-radio-button>\n            </mat-radio-group>\n            <div *ngIf=\"widgetInstance.isMultiple\">\n              <mat-checkbox\n                [formControlName]=\"\n                  widgetInstance.key + '.data.' + question.code + '.' + option.code\n                \"\n                [value]=\"widgetInstance.value['data'][question.code][option.code]\"\n                [checked]=\"true\"\n              ></mat-checkbox>\n            </div>\n          </td>\n          <br />\n          <button *ngIf=\"widgetInstance.button\" mat-icon-button (click)=\"removeMatrixRow(question)\"\n            ><smart-icon icon=\"close\"></smart-icon\n          ></button>\n        </tr>\n      </table>\n    </div>\n    <div *ngIf=\"widgetInstance.type === smartFormWidgetType.YOUTUBE_PLAYER\" class=\"widgetContainer\">\n      <div class=\"labelContainer\">\n        <h4\n          *ngIf=\"widgetInstance.showLabel\"\n          class=\"{{ labelColor }} {{ widgetInstance.cssLabelClass }}\"\n          [ngClass]=\"getLabelNgClass()\"\n          [ngStyle]=\"getLabelStyle()\"\n        >\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n          widgetInstance.hint?.text\n        }}</mat-hint>\n      </div>\n      <youtube-player\n        [ngClass]=\"getNgClass()\"\n        [ngStyle]=\"getStyle()\"\n        videoId=\"{{ widgetInstance.videoId }}\"\n        [width]=\"widgetInstance.width\"\n        [height]=\"widgetInstance.height\"\n        [startSeconds]=\"widgetInstance.startSeconds\"\n        [endSeconds]=\"widgetInstance.endSeconds\"\n      ></youtube-player>\n      <mat-hint\n        *ngIf=\"\n          !widgetInstance?.hint || widgetInstance?.hint?.position === SmartWidgetHintPosition.INPUT\n        \"\n        >{{ widgetInstance.hint?.text }}</mat-hint\n      >\n    </div>\n    <div *ngIf=\"widgetInstance.type === smartFormWidgetType.MONTH_PICKER\" class=\"widgetContainer\">\n      <div class=\"labelContainer\" *ngIf=\"widgetInstance.showLabel\">\n        <h4 class=\"{{ labelColor }} smart-form-widget-label\">\n          {{ getWidgetLabel(widgetInstance) }}\n        </h4>\n        <mat-hint *ngIf=\"widgetInstance?.hint?.position === SmartWidgetHintPosition.LABEL\">{{\n          widgetInstance.hint?.text\n        }}</mat-hint>\n      </div>\n      <lib-smart-month-picker\n        [widgetInstance]=\"widgetInstance\"\n        (valueChange)=\"handleYearMonthPicked($event)\"\n      ></lib-smart-month-picker>\n    </div>\n  </div>\n}\n"]}