1 import { Component, Input, OnInit } from '@angular/core';
2 import { Observable } from 'rxjs/Observable';
3 import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
4 import { FormControl, FormGroup, Validators, ValidationErrors, FormBuilder, ValidatorFn, AbstractControl } from '@angular/forms';
6 import { AlertService } from '../../../@core-xds/services/alert.service';
7 import { ProjectService, IProject } from '../../../@core-xds/services/project.service';
11 selector: 'xds-build-settings-modal',
12 templateUrl: 'build-settings-modal.component.html',
15 export class BuildSettingsModalComponent implements OnInit {
16 // @Input('server-id') serverID: string;
17 private serverID: string;
20 userEditedLabel = false;
22 settingsProjectForm: FormGroup;
23 subpathCtrl = new FormControl('', Validators.nullValidator);
25 private curPrj: IProject;
28 private alert: AlertService,
29 private projectSvr: ProjectService,
30 private fb: FormBuilder,
31 private activeModal: NgbActiveModal,
33 this.settingsProjectForm = fb.group({
34 subpath: this.subpathCtrl,
35 cmdClean: ['', Validators.required],
36 cmdPrebuild: ['', Validators.nullValidator],
37 cmdBuild: ['', Validators.required],
38 cmdPopulate: ['', Validators.nullValidator],
39 cmdArgs: ['', Validators.nullValidator],
40 envVars: ['', Validators.nullValidator],
45 this.curPrj = this.projectSvr.getCurrent();
46 this.settingsProjectForm.patchValue(this.curPrj.uiSettings);
50 this.activeModal.close();
54 this.settingsProjectForm.patchValue(this.projectSvr.getDefaultSettings());
58 if (!this.closeAction) {
62 this.curPrj.uiSettings = this.settingsProjectForm.value;
63 this.projectSvr.setSettings(this.curPrj)
65 this.alert.info('Settings of project "' + prj.label + '" successfully updated.');
68 // Reset Value for the next creation
69 this.settingsProjectForm.reset();
72 this.alert.error(err, 60);