aboutsummaryrefslogtreecommitdiffstats
path: root/vid-webpack-master/src/app/shared/components/genericFormPopup/instantiationTemplatesModal/instantiation.templates.modal.component.ts
blob: 1c86b3ddb94df65b83a1c8951512b33ce25b2fbe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import {Component, OnDestroy, OnInit} from "@angular/core";
import {DialogComponent, DialogService} from "ng2-bootstrap-modal";
import {IframeService} from "../../../utils/iframe.service";
import {ActivatedRoute, Router} from "@angular/router";
import {ServiceInfoService} from "../../../server/serviceInfo/serviceInfo.service";
import {InstantiationTemplatesModalService} from "./instantiation.templates.modal.service";
import {InstantiationTemplatesRowModel} from "./instantiation.templates.row.model";
import {DrawingBoardModes} from "../../../../drawingBoard/service-planning/drawing-board.modes";
import {InstantiationStatusComponentService} from "../../../../instantiationStatus/instantiationStatus.component.service";
import {AaiService} from "../../../services/aaiService/aai.service";
import {NgRedux} from "@angular-redux/store";
import {AppState} from "../../../store/reducers";
import * as _ from 'lodash';
import {forkJoin} from "rxjs";
@Component({
  selector: 'template-modal',
  templateUrl: 'instantiation.templates.modal.component.html',
  styleUrls: ['instantiation.templates.modal.component.scss']
})

export class InstantiationTemplatesModalComponent extends DialogComponent<string, boolean> implements OnInit, OnDestroy {

  serviceModelId: string = null;
  selectedInstantiation: InstantiationTemplatesRowModel = null;
  templateModalComponentService: InstantiationTemplatesModalService;
  originalTableData: InstantiationTemplatesRowModel[] = [];
  filterTableData : InstantiationTemplatesRowModel[] = [];
  filterText: string;
  filterByUserId: boolean = false;

  constructor(dialogService: DialogService,
              private _iframeService: IframeService,
              private _serviceInfoService: ServiceInfoService,
              private _templateModalComponentService: InstantiationTemplatesModalService,
              private _instantiationStatusComponentService: InstantiationStatusComponentService,
              private _aaiService: AaiService,
              private _store : NgRedux<AppState>,
              private _router : Router,
              private _route: ActivatedRoute) {
    super(dialogService);
    this.templateModalComponentService = _templateModalComponentService;
  }

  ngOnInit(): void {
    this.filterText = '';
    this._route
      .queryParams
      .subscribe(params => {
        this.serviceModelId = params['serviceModelId'];
        const getServiceJobInfoRoute = this._serviceInfoService.getTemplatesInfo(true, this.serviceModelId);
        const getUserIdRoute = this._aaiService.getUserId();

        forkJoin([getServiceJobInfoRoute, getUserIdRoute]).subscribe(([jobs]) => {
          this.originalTableData = this._templateModalComponentService.convertResponseToUI(jobs);
          this.filterTableData = this.originalTableData;
        });
      });
  }

  loadTemplate = () => {
    this._instantiationStatusComponentService.navigateToNewViewEdit(this.selectedInstantiation, DrawingBoardModes.RECREATE)
  };

  filterByUserIdChanged = (value : boolean) : void => {
    this.filterByUserId = value;
    const userId: string = this._store.getState().service['userId'];
    if(!_.isNil(userId)){
      this.filterTableData = this.filterByUserId ? this._templateModalComponentService.filterByUserId(userId, this.originalTableData) : this.originalTableData;
    }
  };

  closeModal(): void {
    this._iframeService.closeIframe(this.dialogService, this);
  }


  closeModalAndOpenNewServiceModal(): void {
    this._templateModalComponentService.navigateToNewServiceModal(this.serviceModelId);
  }
}