@tilde-nlp/ngx-common 6.0.30 → 6.0.32

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.
@@ -246,6 +246,7 @@ export class FilterBarComponent {
246
246
  this.cdref.detectChanges();
247
247
  }
248
248
  ngOnDestroy() {
249
+ this.settings.filters?.forEach((filter) => filter.selectedValues = []);
249
250
  this.formChangesSubscription.unsubscribe();
250
251
  }
251
252
  focusOptionSearchInput(filter, index) {
@@ -411,4 +412,4 @@ export class FilterBarComponent {
411
412
  type: Output
412
413
  }] }); })();
413
414
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(FilterBarComponent, { className: "FilterBarComponent", filePath: "lib\\filter-bar\\filter-bar.component.ts", lineNumber: 16 }); })();
414
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.ts","../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild, ViewChildren } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { FilterBarFilter, FilterBarFilterItem } from './models';\r\nimport { FilterBarChangeEvent } from './models/filter-bar-change-event.model';\r\nimport { FilterBarSettings } from './models/filter-bar-settings.model';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { MatSelectChange } from '@angular/material/select';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-filter-bar',\r\n  templateUrl: './filter-bar.component.html',\r\n  styleUrls: ['./filter-bar.component.scss']\r\n})\r\nexport class FilterBarComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @ViewChild(\"filterWrapper\") filterWrapper!: ElementRef;\r\n  @ViewChildren('optionSearchInput') optionSearchInputs!: ElementRef[];\r\n  @HostListener('window:resize', [])\r\n  onResize() {\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Input() settings!: FilterBarSettings;\r\n  @Input() set filterRowVisible(value: boolean) {\r\n    this._filterRowVisible = value;\r\n    this.cdref.detectChanges();\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n\r\n  private _inputText = \"\";\r\n  private _filterRowVisible!: boolean;\r\n  private formChangesSubscription!: Subscription;\r\n\r\n  readonly filterFormGroup = new FormGroup({});\r\n  readonly form = new FormGroup({\r\n    filters: this.filterFormGroup\r\n  });\r\n\r\n  filters: FilterBarChangeEvent = {\r\n    input: '',\r\n    filters: {},\r\n  };\r\n\r\n  filterOverflow = false;\r\n  activeFilterIndex = 0;\r\n\r\n  // getter for cleaner template html\r\n  get filterFormGroupValue(): { [key: string]: FilterBarFilterItem[] } {\r\n    return this.filterFormGroup.value;\r\n  }\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  get filterRowVisible() { return this._filterRowVisible; }\r\n  get inputText() {\r\n    return this._inputText;\r\n  }\r\n  get outputFilterKeyAndValue() {\r\n    return this.settings?.outputFilterKeyAndValue;\r\n  }\r\n  get currentFilters() {\r\n    return this.settings?.splittedFilters?.length ? this.settings.splittedFilters[this.activeFilterIndex] : this.settings?.filters;\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  set inputText(value) {\r\n    this._inputText = value;\r\n    this.filters.input = this._inputText;\r\n    this.emitFilters();\r\n  }\r\n\r\n  constructor(private cdref: ChangeDetectorRef, private translate: TranslateService) { }\r\n\r\n  ngOnInit() {\r\n    this.settings.filters?.forEach((field) => {\r\n      this.filterFormGroup.addControl(field.fieldName, new FormControl([]));\r\n    })\r\n\r\n    this.subscribeToFormValueChanges();\r\n  \r\n    this.activeFilterIndex = 0;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.checkOverflow();\r\n    this.cdref.detectChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.formChangesSubscription.unsubscribe();\r\n  }\r\n\r\n  focusOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder || filter.selectedValues?.length) {\r\n      return;\r\n    }\r\n\r\n    this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement.focus();\r\n\r\n    if (filter.maxPanelWidth === '' && filter.search.placeholder) {\r\n      this.setPanelWidth(filter);\r\n    }\r\n  }\r\n\r\n  clearOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder) {\r\n      return;\r\n    }\r\n\r\n    const input = this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement;\r\n\r\n    if (input) {\r\n      input.value = '';\r\n    }\r\n\r\n    filter.search.searchCriteria = '';\r\n    this.filterOptions(null, filter);\r\n  }\r\n\r\n  filterOptions(event: KeyboardEvent | null, filter: FilterBarFilter) {\r\n    const target = event?.target as HTMLTextAreaElement;\r\n    filter.search!.searchCriteria = target?.value ?? '';\r\n    this.settings.filters?.forEach((item) => {\r\n      if (item.fieldName === filter.fieldName && item.search) {\r\n        item.search.filteredValues = filter.values.filter((value) => {\r\n          const valueKey = item.translated ? value.key : this.translate.instant(value.key);\r\n          const matchesSearch = valueKey.toLowerCase().includes(target?.value?.toLowerCase() ?? '');\r\n          const isSelected = filter.selectedValues?.some((selectedValue) => selectedValue.key === value.key);\r\n          value.isSelected = isSelected ?? false;\r\n          value.matchesSearchCriteria = matchesSearch ?? false;\r\n          return matchesSearch || isSelected;\r\n        })\r\n      }\r\n    });\r\n  }\r\n\r\n  selectEvent(event: MatSelectChange, filter: FilterBarFilter) {\r\n    const settingFilter = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    settingFilter.selectedValues = event.value;\r\n  }\r\n\r\n  setPanelWidth(filter: FilterBarFilter): void {\r\n    // We must save panel width, so filtering does not affect it`s size.\r\n    const selectPanel = document.querySelector('.cdk-overlay-pane') as HTMLElement;\r\n    const selectPanelWidth = selectPanel.clientWidth as number;\r\n    const filterObj = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    filterObj.maxPanelWidth = selectPanelWidth;\r\n    selectPanel.style.minWidth = `${selectPanelWidth}px`;\r\n  }\r\n\r\n  emitFilters() {\r\n    this.filterBarChange.next(this.filters);\r\n  }\r\n\r\n  switchRight() {\r\n    if (this.settings?.splittedFilters?.length === this.activeFilterIndex + 1) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex += 1;\r\n  }\r\n\r\n  switchLeft() {\r\n    if (this.activeFilterIndex === 0) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex -= 1;\r\n  }\r\n\r\n  removeFilter(key: string, ix: number) {\r\n    const control = this.filterFormGroup.get(key);\r\n\r\n    if (!control) {\r\n      return;\r\n    }\r\n\r\n    const newArray = control.value as [];\r\n    newArray.splice(ix, 1);\r\n    control.setValue(newArray);\r\n  }\r\n\r\n  removeAllFilters() {\r\n    this.settings.filters?.forEach((filter) => {\r\n      const valuesArray = this.filterFormGroupValue[filter.fieldName];\r\n      while (valuesArray.length > 0) {\r\n        this.removeFilter(filter.fieldName, 0);\r\n      }\r\n    });\r\n  }\r\n\r\n  private checkOverflow() {\r\n    if (this.filterWrapper?.nativeElement) {\r\n      const minFilterWidth = 100;\r\n  \r\n      if (this.settings?.filters?.length) {\r\n        const containerWidth = this.filterWrapper.nativeElement.clientWidth;\r\n  \r\n        // Calculate the total width needed for all filters\r\n        const totalWidthNeeded = this.settings.filters.length * minFilterWidth;\r\n  \r\n        // If all filters can fit within the container, no need to split\r\n        if (totalWidthNeeded <= containerWidth) {\r\n          this.activeFilterIndex = 0;\r\n          this.settings.splittedFilters = [];\r\n          this.filterOverflow = false;\r\n          return;\r\n        }\r\n  \r\n        // Calculate how many filters can fit per row based on the container width\r\n        const filtersPerRow = Math.floor(containerWidth / minFilterWidth);\r\n  \r\n        // Determine how many groups are needed\r\n        const groupCount = Math.ceil(this.settings.filters.length / filtersPerRow);\r\n\r\n        if (groupCount < this.activeFilterIndex + 1) {\r\n          this.activeFilterIndex = 0;\r\n        }\r\n  \r\n        // Calculate group size based on the number of groups\r\n        const groupSize = Math.ceil(this.settings.filters.length / groupCount);\r\n  \r\n        // Split filters into the calculated number of groups\r\n        const newSplittedFilters: FilterBarFilter[][] = [];\r\n        for (let i = 0; i < this.settings.filters.length; i += groupSize) {\r\n          newSplittedFilters.push(this.settings.filters.slice(i, i + groupSize));\r\n        }\r\n  \r\n        this.settings.splittedFilters = newSplittedFilters;\r\n        this.filterOverflow = true;\r\n      }\r\n    }\r\n  }\r\n  \r\n  private subscribeToFormValueChanges() {\r\n    this.formChangesSubscription = this.form.valueChanges.subscribe(() => {\r\n      this.filters = {\r\n        input: '',\r\n        filters: {}\r\n      };\r\n\r\n      for (const filterKey in this.form.value.filters) {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const filter: FilterBarFilterItem[] = (this.form.value.filters as any)[filterKey] as FilterBarFilterItem[];\r\n        this.filters.filters[filterKey] = filter.map((item) => this.outputFilterKeyAndValue ? item : item.value)\r\n      }\r\n      this.emitFilters();\r\n    })\r\n  }\r\n}\r\n","<div class=\"filter-row\" *ngIf=\"filterRowVisible\">\r\n  <div fxLayout=\"row\" class=\"filter-wrapper\" #filterWrapper [formGroup]=\"form\">\r\n    <ng-container [formGroup]=\"filterFormGroup\">\r\n      <ng-container *ngFor=\"let filter of currentFilters; let i = index\">\r\n        <button [class.filter-active]=\"filter.selectedValues?.length\" class=\"select-trigger-btn\" mat-stroked-button color=\"primary-accent-darker\" (click)=\"select.open()\">\r\n          <div class=\"select-trigger-btn-label\">\r\n            <span>{{filter.title | translate}}</span>\r\n            <span *ngIf=\"filter.selectedValues?.length\" class=\"selected-count\">({{filter.selectedValues?.length}})</span>\r\n            <mat-icon>{{ select.panelOpen ? \"keyboard_arrow_up\" : \"keyboard_arrow_down\" }}</mat-icon>\r\n          </div>\r\n\r\n          <mat-select\r\n            multiple \r\n            #select\r\n            [panelClass]=\"'filter-panel'\"\r\n            [panelWidth]=\"filter?.maxPanelWidth ?? 'auto'\" \r\n            [formControlName]=\"filter.fieldName\" \r\n            (openedChange)=\"$event === true ? focusOptionSearchInput(filter, i) : clearOptionSearchInput(filter, i)\"\r\n            (selectionChange)=\"selectEvent($event, filter)\" \r\n          >\r\n            <ng-container *ngIf=\"filter?.search?.placeholder\">\r\n              <input #optionSearchInput class=\"option-search-input\" [class.hidden]=\"filter.values!.length < 10\" type=\"text\" [placeholder]=\"filter.search?.placeholder ?? '' | translate\" (keyup)=\"filterOptions($event, filter)\" (keydown)=\"$event.stopPropagation()\">\r\n            </ng-container>\r\n          \r\n            <ng-container *ngIf=\"filter.values.length\">\r\n              <ng-container *ngIf=\"filter.translated; else sortedValuesByProperty\">\r\n                <ng-container *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortAlphabetically:'key'\">\r\n                  <mat-option [class.hidden]=\"filter.search?.searchCriteria && value.isSelected && !value.matchesSearchCriteria\" class=\"filter-option\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                    {{ filter.disableTitleCase ? value.key : (value.key | titlecase) }}\r\n                  </mat-option>\r\n                </ng-container>\r\n              </ng-container>\r\n              \r\n              <ng-template #sortedValuesByProperty>\r\n                <ng-container *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortTranslationsByProperty:'key':'value'\">\r\n                  <mat-option [class.hidden]=\"filter.search?.searchCriteria && value.isSelected && !value.matchesSearchCriteria\" class=\"filter-option\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                    <ng-container *ngIf=\"!filter.disableTitleCase; else defaultCase\">\r\n                    {{ value.key | translate : { default: value.value | titlecase } }}\r\n                    </ng-container>\r\n    \r\n                    <ng-template #defaultCase>\r\n                      {{ value.key | translate : { default: value.value } }} \r\n                    </ng-template>\r\n                  </mat-option>\r\n                </ng-container>\r\n              </ng-template>\r\n            </ng-container>\r\n          </mat-select>\r\n        </button>\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n  <ng-container *ngIf=\"filterOverflow\">\r\n    <div class=\"filter-arrows\">\r\n      <button mat-icon-button (click)=\"switchLeft()\">\r\n        <span class=\"material-icons-outlined\">\r\n          chevron_left\r\n        </span>\r\n      </button>\r\n      <button mat-icon-button (click)=\"switchRight()\">\r\n        <span class=\"material-icons-outlined\">\r\n          chevron_right\r\n        </span>\r\n      </button>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n"]}
415
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.ts","../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild, ViewChildren } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { FilterBarFilter, FilterBarFilterItem } from './models';\r\nimport { FilterBarChangeEvent } from './models/filter-bar-change-event.model';\r\nimport { FilterBarSettings } from './models/filter-bar-settings.model';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { MatSelectChange } from '@angular/material/select';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-filter-bar',\r\n  templateUrl: './filter-bar.component.html',\r\n  styleUrls: ['./filter-bar.component.scss']\r\n})\r\nexport class FilterBarComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @ViewChild(\"filterWrapper\") filterWrapper!: ElementRef;\r\n  @ViewChildren('optionSearchInput') optionSearchInputs!: ElementRef[];\r\n  @HostListener('window:resize', [])\r\n  onResize() {\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Input() settings!: FilterBarSettings;\r\n  @Input() set filterRowVisible(value: boolean) {\r\n    this._filterRowVisible = value;\r\n    this.cdref.detectChanges();\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n\r\n  private _inputText = \"\";\r\n  private _filterRowVisible!: boolean;\r\n  private formChangesSubscription!: Subscription;\r\n\r\n  readonly filterFormGroup = new FormGroup({});\r\n  readonly form = new FormGroup({\r\n    filters: this.filterFormGroup\r\n  });\r\n\r\n  filters: FilterBarChangeEvent = {\r\n    input: '',\r\n    filters: {},\r\n  };\r\n\r\n  filterOverflow = false;\r\n  activeFilterIndex = 0;\r\n\r\n  // getter for cleaner template html\r\n  get filterFormGroupValue(): { [key: string]: FilterBarFilterItem[] } {\r\n    return this.filterFormGroup.value;\r\n  }\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  get filterRowVisible() { return this._filterRowVisible; }\r\n  get inputText() {\r\n    return this._inputText;\r\n  }\r\n  get outputFilterKeyAndValue() {\r\n    return this.settings?.outputFilterKeyAndValue;\r\n  }\r\n  get currentFilters() {\r\n    return this.settings?.splittedFilters?.length ? this.settings.splittedFilters[this.activeFilterIndex] : this.settings?.filters;\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  set inputText(value) {\r\n    this._inputText = value;\r\n    this.filters.input = this._inputText;\r\n    this.emitFilters();\r\n  }\r\n\r\n  constructor(private cdref: ChangeDetectorRef, private translate: TranslateService) { }\r\n\r\n  ngOnInit() {\r\n    this.settings.filters?.forEach((field) => {\r\n      this.filterFormGroup.addControl(field.fieldName, new FormControl([]));\r\n    })\r\n\r\n    this.subscribeToFormValueChanges();\r\n  \r\n    this.activeFilterIndex = 0;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.checkOverflow();\r\n    this.cdref.detectChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.settings.filters?.forEach((filter) => filter.selectedValues = []);\r\n    this.formChangesSubscription.unsubscribe();\r\n  }\r\n\r\n  focusOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder || filter.selectedValues?.length) {\r\n      return;\r\n    }\r\n\r\n    this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement.focus();\r\n\r\n    if (filter.maxPanelWidth === '' && filter.search.placeholder) {\r\n      this.setPanelWidth(filter);\r\n    }\r\n  }\r\n\r\n  clearOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder) {\r\n      return;\r\n    }\r\n\r\n    const input = this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement;\r\n\r\n    if (input) {\r\n      input.value = '';\r\n    }\r\n\r\n    filter.search.searchCriteria = '';\r\n    this.filterOptions(null, filter);\r\n  }\r\n\r\n  filterOptions(event: KeyboardEvent | null, filter: FilterBarFilter) {\r\n    const target = event?.target as HTMLTextAreaElement;\r\n    filter.search!.searchCriteria = target?.value ?? '';\r\n    this.settings.filters?.forEach((item) => {\r\n      if (item.fieldName === filter.fieldName && item.search) {\r\n        item.search.filteredValues = filter.values.filter((value) => {\r\n          const valueKey = item.translated ? value.key : this.translate.instant(value.key);\r\n          const matchesSearch = valueKey.toLowerCase().includes(target?.value?.toLowerCase() ?? '');\r\n          const isSelected = filter.selectedValues?.some((selectedValue) => selectedValue.key === value.key);\r\n          value.isSelected = isSelected ?? false;\r\n          value.matchesSearchCriteria = matchesSearch ?? false;\r\n          return matchesSearch || isSelected;\r\n        })\r\n      }\r\n    });\r\n  }\r\n\r\n  selectEvent(event: MatSelectChange, filter: FilterBarFilter) {\r\n    const settingFilter = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    settingFilter.selectedValues = event.value;\r\n  }\r\n\r\n  setPanelWidth(filter: FilterBarFilter): void {\r\n    // We must save panel width, so filtering does not affect it`s size.\r\n    const selectPanel = document.querySelector('.cdk-overlay-pane') as HTMLElement;\r\n    const selectPanelWidth = selectPanel.clientWidth as number;\r\n    const filterObj = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    filterObj.maxPanelWidth = selectPanelWidth;\r\n    selectPanel.style.minWidth = `${selectPanelWidth}px`;\r\n  }\r\n\r\n  emitFilters() {\r\n    this.filterBarChange.next(this.filters);\r\n  }\r\n\r\n  switchRight() {\r\n    if (this.settings?.splittedFilters?.length === this.activeFilterIndex + 1) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex += 1;\r\n  }\r\n\r\n  switchLeft() {\r\n    if (this.activeFilterIndex === 0) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex -= 1;\r\n  }\r\n\r\n  removeFilter(key: string, ix: number) {\r\n    const control = this.filterFormGroup.get(key);\r\n\r\n    if (!control) {\r\n      return;\r\n    }\r\n\r\n    const newArray = control.value as [];\r\n    newArray.splice(ix, 1);\r\n    control.setValue(newArray);\r\n  }\r\n\r\n  removeAllFilters() {\r\n    this.settings.filters?.forEach((filter) => {\r\n      const valuesArray = this.filterFormGroupValue[filter.fieldName];\r\n      while (valuesArray.length > 0) {\r\n        this.removeFilter(filter.fieldName, 0);\r\n      }\r\n    });\r\n  }\r\n\r\n  private checkOverflow() {\r\n    if (this.filterWrapper?.nativeElement) {\r\n      const minFilterWidth = 100;\r\n  \r\n      if (this.settings?.filters?.length) {\r\n        const containerWidth = this.filterWrapper.nativeElement.clientWidth;\r\n  \r\n        // Calculate the total width needed for all filters\r\n        const totalWidthNeeded = this.settings.filters.length * minFilterWidth;\r\n  \r\n        // If all filters can fit within the container, no need to split\r\n        if (totalWidthNeeded <= containerWidth) {\r\n          this.activeFilterIndex = 0;\r\n          this.settings.splittedFilters = [];\r\n          this.filterOverflow = false;\r\n          return;\r\n        }\r\n  \r\n        // Calculate how many filters can fit per row based on the container width\r\n        const filtersPerRow = Math.floor(containerWidth / minFilterWidth);\r\n  \r\n        // Determine how many groups are needed\r\n        const groupCount = Math.ceil(this.settings.filters.length / filtersPerRow);\r\n\r\n        if (groupCount < this.activeFilterIndex + 1) {\r\n          this.activeFilterIndex = 0;\r\n        }\r\n  \r\n        // Calculate group size based on the number of groups\r\n        const groupSize = Math.ceil(this.settings.filters.length / groupCount);\r\n  \r\n        // Split filters into the calculated number of groups\r\n        const newSplittedFilters: FilterBarFilter[][] = [];\r\n        for (let i = 0; i < this.settings.filters.length; i += groupSize) {\r\n          newSplittedFilters.push(this.settings.filters.slice(i, i + groupSize));\r\n        }\r\n  \r\n        this.settings.splittedFilters = newSplittedFilters;\r\n        this.filterOverflow = true;\r\n      }\r\n    }\r\n  }\r\n  \r\n  private subscribeToFormValueChanges() {\r\n    this.formChangesSubscription = this.form.valueChanges.subscribe(() => {\r\n      this.filters = {\r\n        input: '',\r\n        filters: {}\r\n      };\r\n\r\n      for (const filterKey in this.form.value.filters) {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const filter: FilterBarFilterItem[] = (this.form.value.filters as any)[filterKey] as FilterBarFilterItem[];\r\n        this.filters.filters[filterKey] = filter.map((item) => this.outputFilterKeyAndValue ? item : item.value)\r\n      }\r\n      this.emitFilters();\r\n    })\r\n  }\r\n}\r\n","<div class=\"filter-row\" *ngIf=\"filterRowVisible\">\r\n  <div fxLayout=\"row\" class=\"filter-wrapper\" #filterWrapper [formGroup]=\"form\">\r\n    <ng-container [formGroup]=\"filterFormGroup\">\r\n      <ng-container *ngFor=\"let filter of currentFilters; let i = index\">\r\n        <button [class.filter-active]=\"filter.selectedValues?.length\" class=\"select-trigger-btn\" mat-stroked-button color=\"primary-accent-darker\" (click)=\"select.open()\">\r\n          <div class=\"select-trigger-btn-label\">\r\n            <span>{{filter.title | translate}}</span>\r\n            <span *ngIf=\"filter.selectedValues?.length\" class=\"selected-count\">({{filter.selectedValues?.length}})</span>\r\n            <mat-icon>{{ select.panelOpen ? \"keyboard_arrow_up\" : \"keyboard_arrow_down\" }}</mat-icon>\r\n          </div>\r\n\r\n          <mat-select\r\n            multiple \r\n            #select\r\n            [panelClass]=\"'filter-panel'\"\r\n            [panelWidth]=\"filter?.maxPanelWidth ?? 'auto'\" \r\n            [formControlName]=\"filter.fieldName\" \r\n            (openedChange)=\"$event === true ? focusOptionSearchInput(filter, i) : clearOptionSearchInput(filter, i)\"\r\n            (selectionChange)=\"selectEvent($event, filter)\" \r\n          >\r\n            <ng-container *ngIf=\"filter?.search?.placeholder\">\r\n              <input #optionSearchInput class=\"option-search-input\" [class.hidden]=\"filter.values!.length < 10\" type=\"text\" [placeholder]=\"filter.search?.placeholder ?? '' | translate\" (keyup)=\"filterOptions($event, filter)\" (keydown)=\"$event.stopPropagation()\">\r\n            </ng-container>\r\n          \r\n            <ng-container *ngIf=\"filter.values.length\">\r\n              <ng-container *ngIf=\"filter.translated; else sortedValuesByProperty\">\r\n                <ng-container *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortAlphabetically:'key'\">\r\n                  <mat-option [class.hidden]=\"filter.search?.searchCriteria && value.isSelected && !value.matchesSearchCriteria\" class=\"filter-option\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                    {{ filter.disableTitleCase ? value.key : (value.key | titlecase) }}\r\n                  </mat-option>\r\n                </ng-container>\r\n              </ng-container>\r\n              \r\n              <ng-template #sortedValuesByProperty>\r\n                <ng-container *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortTranslationsByProperty:'key':'value'\">\r\n                  <mat-option [class.hidden]=\"filter.search?.searchCriteria && value.isSelected && !value.matchesSearchCriteria\" class=\"filter-option\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                    <ng-container *ngIf=\"!filter.disableTitleCase; else defaultCase\">\r\n                    {{ value.key | translate : { default: value.value | titlecase } }}\r\n                    </ng-container>\r\n    \r\n                    <ng-template #defaultCase>\r\n                      {{ value.key | translate : { default: value.value } }} \r\n                    </ng-template>\r\n                  </mat-option>\r\n                </ng-container>\r\n              </ng-template>\r\n            </ng-container>\r\n          </mat-select>\r\n        </button>\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n  <ng-container *ngIf=\"filterOverflow\">\r\n    <div class=\"filter-arrows\">\r\n      <button mat-icon-button (click)=\"switchLeft()\">\r\n        <span class=\"material-icons-outlined\">\r\n          chevron_left\r\n        </span>\r\n      </button>\r\n      <button mat-icon-button (click)=\"switchRight()\">\r\n        <span class=\"material-icons-outlined\">\r\n          chevron_right\r\n        </span>\r\n      </button>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n"]}
@@ -5,4 +5,5 @@ export * from './language-translate';
5
5
  export * from './date-ago';
6
6
  export * from './object-length';
7
7
  export * from './sort-by-number';
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvcGlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsa0JBQWtCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2ZpbHRlci13aXRoLWhpZ2hsaWdodCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc29ydC10cmFuc2xhdGlvbnMnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NvcnQtdHJhbnNsYXRpb25zLWJ5LXByb3BlcnR5JztcclxuZXhwb3J0ICogZnJvbSAnLi9sYW5ndWFnZS10cmFuc2xhdGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGUtYWdvJztcclxuZXhwb3J0ICogZnJvbSAnLi9vYmplY3QtbGVuZ3RoJztcclxuZXhwb3J0ICogZnJvbSAnLi9zb3J0LWJ5LW51bWJlciciXX0=
8
+ export * from './sort-alphabetically';
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvcGlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyx1QkFBdUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZmlsdGVyLXdpdGgtaGlnaGxpZ2h0JztcclxuZXhwb3J0ICogZnJvbSAnLi9zb3J0LXRyYW5zbGF0aW9ucyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc29ydC10cmFuc2xhdGlvbnMtYnktcHJvcGVydHknO1xyXG5leHBvcnQgKiBmcm9tICcuL2xhbmd1YWdlLXRyYW5zbGF0ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0ZS1hZ28nO1xyXG5leHBvcnQgKiBmcm9tICcuL29iamVjdC1sZW5ndGgnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NvcnQtYnktbnVtYmVyJ1xyXG5leHBvcnQgKiBmcm9tICcuL3NvcnQtYWxwaGFiZXRpY2FsbHknIl19
@@ -1,2 +1,3 @@
1
1
  export * from './sort-alphabetically.module';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvcGlwZXMvc29ydC1hbHBoYWJldGljYWxseS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDhCQUE4QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zb3J0LWFscGhhYmV0aWNhbGx5Lm1vZHVsZSc7Il19
2
+ export * from './sort-alphabetically.pipe';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvcGlwZXMvc29ydC1hbHBoYWJldGljYWxseS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNEJBQTRCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NvcnQtYWxwaGFiZXRpY2FsbHkubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9zb3J0LWFscGhhYmV0aWNhbGx5LnBpcGUnOyJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm9pY2UubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvdGV4dC10by1zcGVlY2gvbW9kZWxzL3ZvaWNlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFZvaWNlIHtcclxuICB2b2ljZTogc3RyaW5nO1xyXG4gIGFwaVZlcnNpb246IG51bWJlcjtcclxuICBhcGlVcmw6IHN0cmluZztcclxuICB2b2ljZU5hbWU/OiBzdHJpbmc7XHJcbn1cclxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm9pY2UubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvdGV4dC10by1zcGVlY2gvbW9kZWxzL3ZvaWNlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFZvaWNlIHtcclxuICB2b2ljZTogc3RyaW5nO1xyXG4gIHZvaWNlTmFtZT86IHN0cmluZztcclxufVxyXG4iXX0=
@@ -4,10 +4,7 @@ import * as i0 from "@angular/core";
4
4
  export class TTSApiService {
5
5
  #http = inject(HttpClient);
6
6
  play(text, voice) {
7
- if (voice.apiVersion === 1) {
8
- return this.#http.get(`${voice.apiUrl}?system=${voice.voice}&text=${text}`, { responseType: 'blob' });
9
- }
10
- return this.#http.post(`${voice.apiUrl}/?text=${text}&voice=${voice.voice}`, null, { responseType: 'blob' });
7
+ return this.#http.get(`https://services.tilde.com/service/tts?system=${voice.voice}&text=${text}`, { responseType: 'blob' });
11
8
  }
12
9
  static { this.ɵfac = function TTSApiService_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TTSApiService)(); }; }
13
10
  static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: TTSApiService, factory: TTSApiService.ɵfac, providedIn: 'root' }); }
@@ -18,4 +15,4 @@ export class TTSApiService {
18
15
  providedIn: 'root',
19
16
  }]
20
17
  }], null, null); })();
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHRzLWFwaS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL3RleHQtdG8tc3BlZWNoL3NlcnZpY2VzL3R0cy1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBT25ELE1BQU0sT0FBTyxhQUFhO0lBQ2YsS0FBSyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUVwQyxJQUFJLENBQUMsSUFBWSxFQUFFLEtBQVk7UUFDN0IsSUFBSSxLQUFLLENBQUMsVUFBVSxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQzNCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQ25CLEdBQUcsS0FBSyxDQUFDLE1BQU0sV0FBVyxLQUFLLENBQUMsS0FBSyxTQUFTLElBQUksRUFBRSxFQUNwRCxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsQ0FDekIsQ0FBQztRQUNKLENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUNwQixHQUFHLEtBQUssQ0FBQyxNQUFNLFVBQVUsSUFBSSxVQUFVLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFDcEQsSUFBSSxFQUNKLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxDQUN6QixDQUFDO0lBQ0osQ0FBQzs4R0FoQlUsYUFBYTt1RUFBYixhQUFhLFdBQWIsYUFBYSxtQkFGWixNQUFNOztpRkFFUCxhQUFhO2NBSHpCLFVBQVU7ZUFBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IFZvaWNlIH0gZnJvbSAnLi4vbW9kZWxzL3ZvaWNlLm1vZGVsJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUVFNBcGlTZXJ2aWNlIHtcclxuICByZWFkb25seSAjaHR0cCA9IGluamVjdChIdHRwQ2xpZW50KTtcclxuXHJcbiAgcGxheSh0ZXh0OiBzdHJpbmcsIHZvaWNlOiBWb2ljZSk6IE9ic2VydmFibGU8QmxvYj4ge1xyXG4gICAgaWYgKHZvaWNlLmFwaVZlcnNpb24gPT09IDEpIHtcclxuICAgICAgcmV0dXJuIHRoaXMuI2h0dHAuZ2V0KFxyXG4gICAgICAgIGAke3ZvaWNlLmFwaVVybH0/c3lzdGVtPSR7dm9pY2Uudm9pY2V9JnRleHQ9JHt0ZXh0fWAsXHJcbiAgICAgICAgeyByZXNwb25zZVR5cGU6ICdibG9iJyB9XHJcbiAgICAgICk7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIHRoaXMuI2h0dHAucG9zdChcclxuICAgICAgYCR7dm9pY2UuYXBpVXJsfS8/dGV4dD0ke3RleHR9JnZvaWNlPSR7dm9pY2Uudm9pY2V9YCxcclxuICAgICAgbnVsbCxcclxuICAgICAgeyByZXNwb25zZVR5cGU6ICdibG9iJyB9XHJcbiAgICApO1xyXG4gIH1cclxufVxyXG4iXX0=
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHRzLWFwaS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL3RleHQtdG8tc3BlZWNoL3NlcnZpY2VzL3R0cy1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBT25ELE1BQU0sT0FBTyxhQUFhO0lBQ2YsS0FBSyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUVwQyxJQUFJLENBQUMsSUFBWSxFQUFFLEtBQVk7UUFDN0IsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FDbkIsaURBQWlELEtBQUssQ0FBQyxLQUFLLFNBQVMsSUFBSSxFQUFFLEVBQzNFLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxDQUN6QixDQUFDO0lBQ0osQ0FBQzs4R0FSVSxhQUFhO3VFQUFiLGFBQWEsV0FBYixhQUFhLG1CQUZaLE1BQU07O2lGQUVQLGFBQWE7Y0FIekIsVUFBVTtlQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgaW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgVm9pY2UgfSBmcm9tICcuLi9tb2RlbHMvdm9pY2UubW9kZWwnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIFRUU0FwaVNlcnZpY2Uge1xyXG4gIHJlYWRvbmx5ICNodHRwID0gaW5qZWN0KEh0dHBDbGllbnQpO1xyXG5cclxuICBwbGF5KHRleHQ6IHN0cmluZywgdm9pY2U6IFZvaWNlKTogT2JzZXJ2YWJsZTxCbG9iPiB7XHJcbiAgICByZXR1cm4gdGhpcy4jaHR0cC5nZXQoXHJcbiAgICAgIGBodHRwczovL3NlcnZpY2VzLnRpbGRlLmNvbS9zZXJ2aWNlL3R0cz9zeXN0ZW09JHt2b2ljZS52b2ljZX0mdGV4dD0ke3RleHR9YCxcclxuICAgICAgeyByZXNwb25zZVR5cGU6ICdibG9iJyB9XHJcbiAgICApO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -20,38 +20,24 @@ import * as i5 from "@angular/material/select";
20
20
  import * as i6 from "@angular/material/core";
21
21
  import * as i7 from "@ngbracket/ngx-layout/extended";
22
22
  import * as i8 from "@ngx-translate/core";
23
- const _c0 = a0 => ({ nth: a0 });
24
- function TextToSpeechComponent_mat_option_6_Conditional_1_Template(rf, ctx) { if (rf & 1) {
25
- i0.ɵɵtext(0);
26
- } if (rf & 2) {
27
- const voice_r1 = i0.ɵɵnextContext().$implicit;
28
- i0.ɵɵtextInterpolate1(" ", voice_r1.voiceName, " ");
29
- } }
30
- function TextToSpeechComponent_mat_option_6_Conditional_2_Template(rf, ctx) { if (rf & 1) {
31
- i0.ɵɵtext(0);
32
- i0.ɵɵpipe(1, "translate");
33
- } if (rf & 2) {
34
- const i_r2 = i0.ɵɵnextContext().index;
35
- i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(1, 1, "voice", i0.ɵɵpureFunction1(4, _c0, i_r2 + 1)), " ");
36
- } }
37
23
  function TextToSpeechComponent_mat_option_6_Template(rf, ctx) { if (rf & 1) {
38
24
  i0.ɵɵelementStart(0, "mat-option", 12);
39
- i0.ɵɵtemplate(1, TextToSpeechComponent_mat_option_6_Conditional_1_Template, 1, 1)(2, TextToSpeechComponent_mat_option_6_Conditional_2_Template, 2, 6);
25
+ i0.ɵɵtext(1);
40
26
  i0.ɵɵelementEnd();
41
27
  } if (rf & 2) {
42
28
  const voice_r1 = ctx.$implicit;
43
29
  i0.ɵɵproperty("value", voice_r1);
44
30
  i0.ɵɵadvance();
45
- i0.ɵɵconditional(voice_r1.voiceName ? 1 : 2);
31
+ i0.ɵɵtextInterpolate1(" ", voice_r1.voiceName, " ");
46
32
  } }
47
33
  function TextToSpeechComponent_mat_icon_17_Template(rf, ctx) { if (rf & 1) {
48
34
  i0.ɵɵelementStart(0, "mat-icon");
49
35
  i0.ɵɵtext(1);
50
36
  i0.ɵɵelementEnd();
51
37
  } if (rf & 2) {
52
- const ctx_r2 = i0.ɵɵnextContext();
38
+ const ctx_r1 = i0.ɵɵnextContext();
53
39
  i0.ɵɵadvance();
54
- i0.ɵɵtextInterpolate1(" ", ctx_r2.isPlaying ? "stop" : "volume_up", " ");
40
+ i0.ɵɵtextInterpolate1(" ", ctx_r1.isPlaying ? "stop" : "volume_up", " ");
55
41
  } }
56
42
  function TextToSpeechComponent_mat_spinner_18_Template(rf, ctx) { if (rf & 1) {
57
43
  i0.ɵɵelement(0, "mat-spinner", 13);
@@ -117,7 +103,7 @@ export class TextToSpeechComponent {
117
103
  i0.ɵɵelementEnd();
118
104
  i0.ɵɵelementStart(5, "mat-select", 2);
119
105
  i0.ɵɵtwoWayListener("valueChange", function TextToSpeechComponent_Template_mat_select_valueChange_5_listener($event) { i0.ɵɵtwoWayBindingSet(ctx.selected, $event) || (ctx.selected = $event); return $event; });
120
- i0.ɵɵtemplate(6, TextToSpeechComponent_mat_option_6_Template, 3, 2, "mat-option", 3);
106
+ i0.ɵɵtemplate(6, TextToSpeechComponent_mat_option_6_Template, 2, 2, "mat-option", 3);
121
107
  i0.ɵɵelementEnd()();
122
108
  i0.ɵɵelementStart(7, "div", 4)(8, "textarea", 5);
123
109
  i0.ɵɵpipe(9, "translate");
@@ -176,11 +162,11 @@ export class TextToSpeechComponent {
176
162
  MatSelectModule,
177
163
  FlexLayoutModule,
178
164
  TranslateModule
179
- ], template: "<div [ngClass.lt-md]=\"'mobile'\" class=\"text-to-speech-wrapper\">\r\n <mat-form-field appearance=\"outline\" color=\"accent\">\r\n <mat-label>{{\"selectVoice\" | translate }}</mat-label>\r\n <mat-select [(value)]=\"selected\">\r\n <mat-option *ngFor=\"let voice of voices; let i = index\" [value]=\"voice\">\r\n @if(voice.voiceName){\r\n {{voice.voiceName}}\r\n }\r\n @else{\r\n {{ 'voice' | translate: {nth: i + 1} }}\r\n }\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <div class=\"text-to-speech-textarea-wrapper\">\r\n <textarea [(ngModel)]=\"text\" class=\"text-to-speech-textarea\" [placeholder]=\"'placeholder' | translate\"></textarea>\r\n <div [class.text-overflow]=\"hasOverflow\" class=\"text-to-speech-characters\">\r\n {{text?.length ?? 0}}/{{maxCharLength}}\r\n </div>\r\n </div>\r\n\r\n <div class=\"text-to-speech-actions\">\r\n <div [matTooltip]=\"!text ? ('playDisabled' | translate) : ''\">\r\n <button [matTooltip]=\"(isPlaying ? 'stop' : 'play') | translate\" [disabled]=\"!text || isLoading\" (click)=\"togglePlay()\" mat-icon-button>\r\n <mat-icon *ngIf=\"!isLoading\"> {{ isPlaying ? 'stop' : 'volume_up' }} </mat-icon>\r\n <mat-spinner *ngIf=\"isLoading\" [diameter]=\"15\"></mat-spinner>\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".text-to-speech-wrapper{margin-top:5px;position:relative;display:flex;flex-direction:column;align-items:center}.text-to-speech-wrapper mat-form-field{max-width:900px!important;width:100%}.text-to-speech-textarea-wrapper,.text-to-speech-textarea{position:relative;width:100%;max-width:900px}.text-to-speech-textarea-wrapper{border:1px solid var(--base-70);padding:5px;border-radius:8px;box-shadow:0 0 16px #0000001a}.text-to-speech-textarea{margin:15px 0;padding:0 10px;min-height:120px;resize:none;outline:none;border:none}.text-to-speech-actions{position:absolute;bottom:-20px}.text-to-speech-actions button{display:flex;justify-content:center;color:var(--base-100)!important;background-color:var(--accent)}.text-to-speech-actions button:disabled{background-color:var(--base-70)}.text-to-speech-actions button mat-spinner{scale:1.2}.text-to-speech-characters{position:absolute;right:10px;bottom:0;margin:5px;font-size:13px;color:var(--base-65)}.text-overflow{right:30px}.mobile .text-overflow{right:15px}\n"] }]
165
+ ], template: "<div [ngClass.lt-md]=\"'mobile'\" class=\"text-to-speech-wrapper\">\r\n <mat-form-field appearance=\"outline\" color=\"accent\">\r\n <mat-label>{{\"selectVoice\" | translate }}</mat-label>\r\n <mat-select [(value)]=\"selected\">\r\n <mat-option *ngFor=\"let voice of voices; let i = index\" [value]=\"voice\">\r\n {{voice.voiceName}}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <div class=\"text-to-speech-textarea-wrapper\">\r\n <textarea [(ngModel)]=\"text\" class=\"text-to-speech-textarea\" [placeholder]=\"'placeholder' | translate\"></textarea>\r\n <div [class.text-overflow]=\"hasOverflow\" class=\"text-to-speech-characters\">\r\n {{text?.length ?? 0}}/{{maxCharLength}}\r\n </div>\r\n </div>\r\n\r\n <div class=\"text-to-speech-actions\">\r\n <div [matTooltip]=\"!text ? ('playDisabled' | translate) : ''\">\r\n <button [matTooltip]=\"(isPlaying ? 'stop' : 'play') | translate\" [disabled]=\"!text || isLoading\" (click)=\"togglePlay()\" mat-icon-button>\r\n <mat-icon *ngIf=\"!isLoading\"> {{ isPlaying ? 'stop' : 'volume_up' }} </mat-icon>\r\n <mat-spinner *ngIf=\"isLoading\" [diameter]=\"15\"></mat-spinner>\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".text-to-speech-wrapper{margin-top:5px;position:relative;display:flex;flex-direction:column;align-items:center}.text-to-speech-wrapper mat-form-field{max-width:900px!important;width:100%}.text-to-speech-textarea-wrapper,.text-to-speech-textarea{position:relative;width:100%;max-width:900px}.text-to-speech-textarea-wrapper{border:1px solid var(--base-70);padding:5px;border-radius:8px;box-shadow:0 0 16px #0000001a}.text-to-speech-textarea{margin:15px 0;padding:0 10px;min-height:120px;resize:none;outline:none;border:none}.text-to-speech-actions{position:absolute;bottom:-20px}.text-to-speech-actions button{display:flex;justify-content:center;color:var(--base-100)!important;background-color:var(--accent)}.text-to-speech-actions button:disabled{background-color:var(--base-70)}.text-to-speech-actions button mat-spinner{scale:1.2}.text-to-speech-characters{position:absolute;right:10px;bottom:0;margin:5px;font-size:13px;color:var(--base-65)}.text-overflow{right:30px}.mobile .text-overflow{right:15px}\n"] }]
180
166
  }], null, { maxCharLength: [{
181
167
  type: Input
182
168
  }], voices: [{
183
169
  type: Input
184
170
  }] }); })();
185
171
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TextToSpeechComponent, { className: "TextToSpeechComponent", filePath: "lib\\text-to-speech\\text-to-speech.component.ts", lineNumber: 35 }); })();
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-to-speech.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/text-to-speech/text-to-speech.component.ts","../../../../../projects/ngx-common/src/lib/text-to-speech/text-to-speech.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, inject, Input, OnInit } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatButton, MatIconButton } from '@angular/material/button';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { TTSApiService } from './services/tts-api.service';\r\nimport { finalize } from 'rxjs';\r\nimport { MatProgressSpinner } from '@angular/material/progress-spinner';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { Voice } from './models/voice.model';\r\n\r\n@Component({\r\n  selector: 'lib-text-to-speech',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    MatButton,\r\n    MatIconButton,\r\n    MatIcon,\r\n    FormsModule,\r\n    MatProgressSpinner,\r\n    MatTooltipModule,\r\n    MatFormFieldModule,\r\n    MatSelectModule,\r\n    FlexLayoutModule,\r\n    TranslateModule\r\n  ],\r\n  templateUrl: './text-to-speech.component.html',\r\n  styleUrl: './text-to-speech.component.scss',\r\n})\r\nexport class TextToSpeechComponent implements OnInit {\r\n  @Input() maxCharLength: number = 1000;\r\n  @Input() voices!: Voice[];\r\n\r\n  text!: string;\r\n  previousText!: string;\r\n  previousVoice!: string;\r\n  audio!: HTMLAudioElement;\r\n  isLoading!: boolean;\r\n  isPlaying!: boolean;\r\n  \r\n  selected!: Voice;\r\n\r\n  get hasOverflow() {\r\n    const textarea = document.querySelector('textarea') as HTMLTextAreaElement;\r\n    return textarea?.clientHeight < textarea?.scrollHeight ? true : false\r\n  }\r\n\r\n  readonly #TTSApiService = inject(TTSApiService);\r\n\r\n  ngOnInit(): void {\r\n    this.selected = this.voices[0];\r\n  }\r\n\r\n  togglePlay(): void {\r\n    if (this.isPlaying) {\r\n      this.stop();\r\n      return;\r\n    }\r\n\r\n    this.isLoading = true;\r\n\r\n    const text = this.text.length > this.maxCharLength ? this.text.substring(0, this.maxCharLength) : this.text;\r\n\r\n    if ((this.audio && text === this.previousText) && (this.selected.voice === this.previousVoice)) {\r\n      this.audio.play();\r\n      this.isPlaying = true;\r\n      this.isLoading = false;\r\n      return;\r\n    }\r\n\r\n    this.#TTSApiService\r\n      .play(text, this.selected)\r\n      .pipe(finalize(() => { this.isLoading = false }))\r\n      .subscribe({\r\n        next: (res) => {\r\n          this.previousText = text;\r\n          this.previousVoice = this.selected.voice;\r\n          const audioUrl = URL.createObjectURL(res);\r\n          this.audio = new Audio(audioUrl);\r\n          this.audio.play();\r\n\r\n          this.isPlaying = true;\r\n\r\n          this.audio.onended = () => {\r\n            URL.revokeObjectURL(audioUrl);\r\n            this.isPlaying = false;\r\n          };\r\n        },\r\n      });\r\n  }\r\n\r\n  stop(): void {\r\n    if (this.audio) {\r\n      this.audio.pause();\r\n      this.audio.currentTime = 0;\r\n      this.isPlaying = false;\r\n    }\r\n  }\r\n}\r\n","<div [ngClass.lt-md]=\"'mobile'\" class=\"text-to-speech-wrapper\">\r\n  <mat-form-field appearance=\"outline\" color=\"accent\">\r\n    <mat-label>{{\"selectVoice\" | translate }}</mat-label>\r\n    <mat-select [(value)]=\"selected\">\r\n      <mat-option *ngFor=\"let voice of voices; let i = index\" [value]=\"voice\">\r\n        @if(voice.voiceName){\r\n          {{voice.voiceName}}\r\n        }\r\n        @else{\r\n        {{ 'voice' | translate: {nth: i + 1} }}\r\n        }\r\n      </mat-option>\r\n    </mat-select>\r\n  </mat-form-field>\r\n\r\n  <div class=\"text-to-speech-textarea-wrapper\">\r\n    <textarea [(ngModel)]=\"text\" class=\"text-to-speech-textarea\" [placeholder]=\"'placeholder' | translate\"></textarea>\r\n    <div [class.text-overflow]=\"hasOverflow\" class=\"text-to-speech-characters\">\r\n      {{text?.length ?? 0}}/{{maxCharLength}}\r\n    </div>\r\n  </div>\r\n\r\n  <div class=\"text-to-speech-actions\">\r\n    <div [matTooltip]=\"!text ? ('playDisabled' | translate) : ''\">\r\n      <button [matTooltip]=\"(isPlaying ? 'stop' : 'play') | translate\" [disabled]=\"!text || isLoading\" (click)=\"togglePlay()\" mat-icon-button>\r\n        <mat-icon *ngIf=\"!isLoading\"> {{ isPlaying ? 'stop' : 'volume_up' }}  </mat-icon>\r\n        <mat-spinner *ngIf=\"isLoading\" [diameter]=\"15\"></mat-spinner>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
172
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-to-speech.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/text-to-speech/text-to-speech.component.ts","../../../../../projects/ngx-common/src/lib/text-to-speech/text-to-speech.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, inject, Input, OnInit } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatButton, MatIconButton } from '@angular/material/button';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { TTSApiService } from './services/tts-api.service';\r\nimport { finalize } from 'rxjs';\r\nimport { MatProgressSpinner } from '@angular/material/progress-spinner';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { Voice } from './models/voice.model';\r\n\r\n@Component({\r\n  selector: 'lib-text-to-speech',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    MatButton,\r\n    MatIconButton,\r\n    MatIcon,\r\n    FormsModule,\r\n    MatProgressSpinner,\r\n    MatTooltipModule,\r\n    MatFormFieldModule,\r\n    MatSelectModule,\r\n    FlexLayoutModule,\r\n    TranslateModule\r\n  ],\r\n  templateUrl: './text-to-speech.component.html',\r\n  styleUrl: './text-to-speech.component.scss',\r\n})\r\nexport class TextToSpeechComponent implements OnInit {\r\n  @Input() maxCharLength: number = 1000;\r\n  @Input() voices!: Voice[];\r\n\r\n  text!: string;\r\n  previousText!: string;\r\n  previousVoice!: string;\r\n  audio!: HTMLAudioElement;\r\n  isLoading!: boolean;\r\n  isPlaying!: boolean;\r\n  \r\n  selected!: Voice;\r\n\r\n  get hasOverflow() {\r\n    const textarea = document.querySelector('textarea') as HTMLTextAreaElement;\r\n    return textarea?.clientHeight < textarea?.scrollHeight ? true : false\r\n  }\r\n\r\n  readonly #TTSApiService = inject(TTSApiService);\r\n\r\n  ngOnInit(): void {\r\n    this.selected = this.voices[0];\r\n  }\r\n\r\n  togglePlay(): void {\r\n    if (this.isPlaying) {\r\n      this.stop();\r\n      return;\r\n    }\r\n\r\n    this.isLoading = true;\r\n\r\n    const text = this.text.length > this.maxCharLength ? this.text.substring(0, this.maxCharLength) : this.text;\r\n\r\n    if ((this.audio && text === this.previousText) && (this.selected.voice === this.previousVoice)) {\r\n      this.audio.play();\r\n      this.isPlaying = true;\r\n      this.isLoading = false;\r\n      return;\r\n    }\r\n\r\n    this.#TTSApiService\r\n      .play(text, this.selected)\r\n      .pipe(finalize(() => { this.isLoading = false }))\r\n      .subscribe({\r\n        next: (res) => {\r\n          this.previousText = text;\r\n          this.previousVoice = this.selected.voice;\r\n          const audioUrl = URL.createObjectURL(res);\r\n          this.audio = new Audio(audioUrl);\r\n          this.audio.play();\r\n\r\n          this.isPlaying = true;\r\n\r\n          this.audio.onended = () => {\r\n            URL.revokeObjectURL(audioUrl);\r\n            this.isPlaying = false;\r\n          };\r\n        },\r\n      });\r\n  }\r\n\r\n  stop(): void {\r\n    if (this.audio) {\r\n      this.audio.pause();\r\n      this.audio.currentTime = 0;\r\n      this.isPlaying = false;\r\n    }\r\n  }\r\n}\r\n","<div [ngClass.lt-md]=\"'mobile'\" class=\"text-to-speech-wrapper\">\r\n  <mat-form-field appearance=\"outline\" color=\"accent\">\r\n    <mat-label>{{\"selectVoice\" | translate }}</mat-label>\r\n    <mat-select [(value)]=\"selected\">\r\n      <mat-option *ngFor=\"let voice of voices; let i = index\" [value]=\"voice\">\r\n        {{voice.voiceName}}\r\n      </mat-option>\r\n    </mat-select>\r\n  </mat-form-field>\r\n\r\n  <div class=\"text-to-speech-textarea-wrapper\">\r\n    <textarea [(ngModel)]=\"text\" class=\"text-to-speech-textarea\" [placeholder]=\"'placeholder' | translate\"></textarea>\r\n    <div [class.text-overflow]=\"hasOverflow\" class=\"text-to-speech-characters\">\r\n      {{text?.length ?? 0}}/{{maxCharLength}}\r\n    </div>\r\n  </div>\r\n\r\n  <div class=\"text-to-speech-actions\">\r\n    <div [matTooltip]=\"!text ? ('playDisabled' | translate) : ''\">\r\n      <button [matTooltip]=\"(isPlaying ? 'stop' : 'play') | translate\" [disabled]=\"!text || isLoading\" (click)=\"togglePlay()\" mat-icon-button>\r\n        <mat-icon *ngIf=\"!isLoading\"> {{ isPlaying ? 'stop' : 'volume_up' }}  </mat-icon>\r\n        <mat-spinner *ngIf=\"isLoading\" [diameter]=\"15\"></mat-spinner>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}