adjuster.component.ts 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. import {Component, ViewRef} from '@angular/core';
  2. import {HsLayoutService} from 'hslayers-ng/components/layout/layout.service';
  3. import {HsPanelComponent} from 'hslayers-ng/components/layout/panels/panel-component.interface';
  4. import {AdjusterEventService} from './adjuster-event.service';
  5. import {AdjusterService} from './adjuster.service';
  6. @Component({
  7. selector: 'pra-adjuster',
  8. template: require('./adjuster.directive.html'),
  9. })
  10. export class AdjusterComponent implements HsPanelComponent {
  11. data: any;
  12. descriptionVisible: boolean;
  13. errorMsg: string;
  14. method: string;
  15. viewRef: ViewRef;
  16. constructor(
  17. private adjusterService: AdjusterService,
  18. private adjusterEventService: AdjusterEventService,
  19. private hsLayoutService: HsLayoutService
  20. ) {
  21. this.descriptionVisible = false;
  22. this.method = this.adjusterService.method;
  23. this.adjusterEventService.clustersLoaded.subscribe(({success, err}) => {
  24. if (!success) {
  25. this.errorMsg = err.message;
  26. }
  27. });
  28. }
  29. isVisible(): boolean {
  30. return this.hsLayoutService.panelVisible('adjuster');
  31. }
  32. noDataSelected(): boolean {
  33. if (this.adjusterService.factors.length === 0) {
  34. return true;
  35. }
  36. let datasetsEffectivelyTurnedOn = [];
  37. for (const factor of this.adjusterService.factors) {
  38. if (factor.weight === 0) {
  39. continue;
  40. }
  41. datasetsEffectivelyTurnedOn = [
  42. ...datasetsEffectivelyTurnedOn,
  43. ...factor.datasets.filter((ds) => ds.included),
  44. ];
  45. }
  46. return datasetsEffectivelyTurnedOn.length === 0;
  47. }
  48. selectMethod(): void {
  49. this.adjusterService.method = this.method;
  50. this.adjusterEventService.methodChanged.next(this.method);
  51. }
  52. }