import { Component, OnInit } from '@angular/core'; import { ConfigurationService } from './configuration.service'; import { Bean, PropertySource } from './configuration.model'; @Component({ selector: 'jhi-configuration', templateUrl: './configuration.component.html', }) export class ConfigurationComponent implements OnInit { allBeans!: Bean[]; beans: Bean[] = []; beansFilter = ''; beansAscending = true; propertySources: PropertySource[] = []; constructor(private configurationService: ConfigurationService) {} ngOnInit(): void { this.configurationService.getBeans().subscribe(beans => { this.allBeans = beans; this.filterAndSortBeans(); }); this.configurationService.getPropertySources().subscribe(propertySources => (this.propertySources = propertySources)); } filterAndSortBeans(): void { const beansAscendingValue = this.beansAscending ? -1 : 1; const beansAscendingValueReverse = this.beansAscending ? 1 : -1; this.beans = this.allBeans .filter(bean => !this.beansFilter || bean.prefix.toLowerCase().includes(this.beansFilter.toLowerCase())) .sort((a, b) => (a.prefix < b.prefix ? beansAscendingValue : beansAscendingValueReverse)); } }