@lowcodeunit/applications-flow-common 1.33.97-lets-get-social-ish → 1.33.98-lets-get-social-ish
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.
- package/bundles/lowcodeunit-applications-flow-common.umd.js +434 -6
- package/bundles/lowcodeunit-applications-flow-common.umd.js.map +1 -1
- package/bundles/lowcodeunit-applications-flow-common.umd.min.js +2 -2
- package/bundles/lowcodeunit-applications-flow-common.umd.min.js.map +1 -1
- package/esm2015/lib/controls/build-pipeline-form/build-pipeline-form.component.js +69 -5
- package/esm2015/lib/controls/devops-source-control-form/devops-source-control-form.component.js +301 -5
- package/esm2015/lib/elements/projects/controls/hosting-details-form-group/hosting-details-form-group.component.js +1 -1
- package/fesm2015/lowcodeunit-applications-flow-common.js +359 -6
- package/fesm2015/lowcodeunit-applications-flow-common.js.map +1 -1
- package/lib/controls/build-pipeline-form/build-pipeline-form.component.d.ts +27 -1
- package/lib/controls/build-pipeline-form/build-pipeline-form.component.d.ts.map +1 -1
- package/lib/controls/devops-source-control-form/devops-source-control-form.component.d.ts +67 -3
- package/lib/controls/devops-source-control-form/devops-source-control-form.component.d.ts.map +1 -1
- package/lib/elements/projects/controls/hosting-details-form-group/hosting-details-form-group.component.d.ts.map +1 -1
- package/lowcodeunit-applications-flow-common.metadata.json +1 -1
- package/package.json +1 -1
|
@@ -1,15 +1,79 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { FormBuilder } from '@angular/forms';
|
|
3
|
+
import { ApplicationsFlowService } from '../../services/applications-flow.service';
|
|
4
|
+
import { ProjectHostingDetails } from '../../state/applications-flow.state';
|
|
2
5
|
export class BuildPipelineFormComponent {
|
|
3
|
-
constructor() {
|
|
6
|
+
constructor(formBldr, appsFlowSvc) {
|
|
7
|
+
this.formBldr = formBldr;
|
|
8
|
+
this.appsFlowSvc = appsFlowSvc;
|
|
9
|
+
this.HostingDetails = new ProjectHostingDetails();
|
|
10
|
+
}
|
|
11
|
+
//PROPERTIES
|
|
12
|
+
get Artifact() {
|
|
13
|
+
var _a, _b;
|
|
14
|
+
return ((_a = this.Environment) === null || _a === void 0 ? void 0 : _a.Artifacts) && this.ArtifactLookup
|
|
15
|
+
? ((_b = this.Environment) === null || _b === void 0 ? void 0 : _b.Artifacts[this.ArtifactLookup]) || {}
|
|
16
|
+
: {};
|
|
17
|
+
}
|
|
18
|
+
get ArtifactLookup() {
|
|
19
|
+
var _a, _b;
|
|
20
|
+
const artLookup = ((_a = this.DevOpsAction) === null || _a === void 0 ? void 0 : _a.ArtifactLookups) ? (_b = this.DevOpsAction) === null || _b === void 0 ? void 0 : _b.ArtifactLookups[0] : null;
|
|
21
|
+
return artLookup;
|
|
22
|
+
}
|
|
23
|
+
get DevOpsAction() {
|
|
24
|
+
return this.Environment.DevOpsActions && this.DevOpsActionLookup
|
|
25
|
+
? this.Environment.DevOpsActions[this.DevOpsActionLookup] || {}
|
|
26
|
+
: {};
|
|
27
|
+
}
|
|
28
|
+
get DevOpsActions() {
|
|
29
|
+
return this.Environment.DevOpsActions || {};
|
|
30
|
+
}
|
|
31
|
+
get EditingSourceControl() {
|
|
32
|
+
var _a, _b;
|
|
33
|
+
let sc = ((_a = this.Environment) === null || _a === void 0 ? void 0 : _a.Sources) ? (_b = this.Environment) === null || _b === void 0 ? void 0 : _b.Sources[this.EditingSourceControlLookup] : null;
|
|
34
|
+
if (sc == null && this.EditingSourceControlLookup) {
|
|
35
|
+
sc = {};
|
|
36
|
+
}
|
|
37
|
+
return sc;
|
|
38
|
+
}
|
|
39
|
+
get SourceControlLookups() {
|
|
40
|
+
return Object.keys(this.SourceControls || {});
|
|
41
|
+
}
|
|
42
|
+
get SourceControls() {
|
|
43
|
+
return this.Environment.Sources || {};
|
|
44
|
+
}
|
|
4
45
|
ngOnInit() {
|
|
5
46
|
}
|
|
47
|
+
//API METHODS
|
|
48
|
+
//HELPERS
|
|
49
|
+
loadProjectHostingDetails() {
|
|
50
|
+
this.HostingDetails.Loading = true;
|
|
51
|
+
this.appsFlowSvc
|
|
52
|
+
.LoadProjectHostingDetails(this.Organization, this.Repository, this.MainBranch)
|
|
53
|
+
.subscribe((response) => {
|
|
54
|
+
this.HostingDetails = response.Model;
|
|
55
|
+
this.HostingDetails.Loading = false;
|
|
56
|
+
}, (err) => {
|
|
57
|
+
this.HostingDetails.Loading = false;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
6
60
|
}
|
|
7
61
|
BuildPipelineFormComponent.decorators = [
|
|
8
62
|
{ type: Component, args: [{
|
|
9
63
|
selector: 'lcu-build-pipeline-form',
|
|
10
|
-
template: "<
|
|
64
|
+
template: "<div class=\"form-card\" fxFlex=\"35%\" fxFlex.lt-md=\"100%\">\n <mat-card\n class=\"spread\"\n *ngIf=\"EditingSourceControl?.Branches?.length > 0\"\n >\n <mat-card-header>\n <mat-card-title> Build Pipeline </mat-card-title>\n\n <mat-hint>\n Changes made here are reflected for all sources using this\n DevOpsAction\n </mat-hint>\n </mat-card-header>\n\n <mat-card-content>\n\n <ng-container>\n <lcu-hosting-details-form-group\n [artifact]=\"Artifact\"\n [devops-action]=\"DevOpsActions[DevOpsActionLookup]\"\n [details]=\"HostingDetails\"\n [formGroup]=\"DevOpsFormGroup\"\n [organization]=\"Organization\"\n [disabled]=\"HostingDetails?.Loading\"\n ></lcu-hosting-details-form-group>\n </ng-container>\n </mat-card-content>\n </mat-card>\n </div>\n",
|
|
11
65
|
styles: [""]
|
|
12
66
|
},] }
|
|
13
67
|
];
|
|
14
|
-
BuildPipelineFormComponent.ctorParameters = () => [
|
|
15
|
-
|
|
68
|
+
BuildPipelineFormComponent.ctorParameters = () => [
|
|
69
|
+
{ type: FormBuilder },
|
|
70
|
+
{ type: ApplicationsFlowService }
|
|
71
|
+
];
|
|
72
|
+
BuildPipelineFormComponent.propDecorators = {
|
|
73
|
+
DevOpsActionLookup: [{ type: Input, args: ['devops-action-lookup',] }],
|
|
74
|
+
Environment: [{ type: Input, args: ['environment',] }],
|
|
75
|
+
MainBranch: [{ type: Input, args: ['main-branch',] }],
|
|
76
|
+
Organization: [{ type: Input, args: ['organization',] }],
|
|
77
|
+
Repository: [{ type: Input, args: ['repository',] }]
|
|
78
|
+
};
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtcGlwZWxpbmUtZm9ybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiL2hvbWUvcnVubmVyL3dvcmsvYXBwbGljYXRpb25zLWZsb3cvYXBwbGljYXRpb25zLWZsb3cvcHJvamVjdHMvY29tbW9uL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jb250cm9scy9idWlsZC1waXBlbGluZS1mb3JtL2J1aWxkLXBpcGVsaW5lLWZvcm0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxXQUFXLEVBQWEsTUFBTSxnQkFBZ0IsQ0FBQztBQUd4RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUNuRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQU81RSxNQUFNLE9BQU8sMEJBQTBCO0lBMEVyQyxZQUFzQixRQUFxQixFQUMvQixXQUFvQztRQUQxQixhQUFRLEdBQVIsUUFBUSxDQUFhO1FBQy9CLGdCQUFXLEdBQVgsV0FBVyxDQUF5QjtRQUM5QyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUkscUJBQXFCLEVBQUUsQ0FBQztJQUNuRCxDQUFDO0lBMUVKLFlBQVk7SUFFWixJQUFXLFFBQVE7O1FBQ2pCLE9BQU8sT0FBQSxJQUFJLENBQUMsV0FBVywwQ0FBRSxTQUFTLEtBQUksSUFBSSxDQUFDLGNBQWM7WUFDdkQsQ0FBQyxDQUFDLE9BQUEsSUFBSSxDQUFDLFdBQVcsMENBQUUsU0FBUyxDQUFDLElBQUksQ0FBQyxjQUFjLE1BQUssRUFBRTtZQUN4RCxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQ1QsQ0FBQztJQUVELElBQVcsY0FBYzs7UUFDdkIsTUFBTSxTQUFTLEdBQUcsT0FBQSxJQUFJLENBQUMsWUFBWSwwQ0FBRSxlQUFlLEVBQ2xELENBQUMsT0FBQyxJQUFJLENBQUMsWUFBWSwwQ0FBRSxlQUFlLENBQUMsQ0FBQyxFQUN0QyxDQUFDLENBQUMsSUFBSSxDQUFDO1FBRVQsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUlELElBQVcsWUFBWTtRQUNyQixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxJQUFJLElBQUksQ0FBQyxrQkFBa0I7WUFDOUQsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLEVBQUU7WUFDL0QsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUNULENBQUM7SUFLRCxJQUFXLGFBQWE7UUFDdEIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsSUFBSSxFQUFFLENBQUM7SUFDOUMsQ0FBQztJQU1ELElBQVcsb0JBQW9COztRQUMzQixJQUFJLEVBQUUsR0FBRyxPQUFBLElBQUksQ0FBQyxXQUFXLDBDQUFFLE9BQU8sRUFDaEMsQ0FBQyxPQUFDLElBQUksQ0FBQyxXQUFXLDBDQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsMEJBQTBCLEVBQzNELENBQUMsQ0FBQyxJQUFJLENBQUM7UUFFVCxJQUFJLEVBQUUsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLDBCQUEwQixFQUFFO1lBQ2pELEVBQUUsR0FBRyxFQUFFLENBQUM7U0FDVDtRQUVELE9BQU8sRUFBRSxDQUFDO0lBQ1osQ0FBQztJQWtCRCxJQUFXLG9CQUFvQjtRQUM3QixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNoRCxDQUFDO0lBRUQsSUFBVyxjQUFjO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO0lBQ3hDLENBQUM7SUFPTSxRQUFRO0lBRWYsQ0FBQztJQUVILGFBQWE7SUFFYixTQUFTO0lBQ0MseUJBQXlCO1FBQy9CLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztRQUVuQyxJQUFJLENBQUMsV0FBVzthQUNiLHlCQUF5QixDQUN4QixJQUFJLENBQUMsWUFBWSxFQUNqQixJQUFJLENBQUMsVUFBVSxFQUNmLElBQUksQ0FBQyxVQUFVLENBQ2hCO2FBQ0EsU0FBUyxDQUNSLENBQUMsUUFBb0QsRUFBRSxFQUFFO1lBQ3ZELElBQUksQ0FBQyxjQUFjLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQztZQUVyQyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFFdEMsQ0FBQyxFQUNELENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDTixJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDdEMsQ0FBQyxDQUNGLENBQUM7SUFFUixDQUFDOzs7WUFoSEEsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSx5QkFBeUI7Z0JBQ25DLDI2QkFBbUQ7O2FBRXBEOzs7WUFWUSxXQUFXO1lBR1gsdUJBQXVCOzs7aUNBbUMvQixLQUFLLFNBQUMsc0JBQXNCOzBCQXVCMUIsS0FBSyxTQUFDLGFBQWE7eUJBT25CLEtBQUssU0FBQyxhQUFhOzJCQUduQixLQUFLLFNBQUMsY0FBYzt5QkFHcEIsS0FBSyxTQUFDLFlBQVkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1CdWlsZGVyLCBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBCYXNlTW9kZWxlZFJlc3BvbnNlIH0gZnJvbSAnQGxjdS9jb21tb24nO1xuaW1wb3J0IHsgRWFDQXJ0aWZhY3QsIEVhQ0Rldk9wc0FjdGlvbiwgRWFDRW52aXJvbm1lbnRBc0NvZGUsIEVhQ1NvdXJjZUNvbnRyb2wgfSBmcm9tICdAc2VtYW50aWNqcy9jb21tb24nO1xuaW1wb3J0IHsgQXBwbGljYXRpb25zRmxvd1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9hcHBsaWNhdGlvbnMtZmxvdy5zZXJ2aWNlJztcbmltcG9ydCB7IFByb2plY3RIb3N0aW5nRGV0YWlscyB9IGZyb20gJy4uLy4uL3N0YXRlL2FwcGxpY2F0aW9ucy1mbG93LnN0YXRlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGN1LWJ1aWxkLXBpcGVsaW5lLWZvcm0nLFxuICB0ZW1wbGF0ZVVybDogJy4vYnVpbGQtcGlwZWxpbmUtZm9ybS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2J1aWxkLXBpcGVsaW5lLWZvcm0uY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBCdWlsZFBpcGVsaW5lRm9ybUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cblxuLy9QUk9QRVJUSUVTXG5cbnB1YmxpYyBnZXQgQXJ0aWZhY3QoKTogRWFDQXJ0aWZhY3Qge1xuICByZXR1cm4gdGhpcy5FbnZpcm9ubWVudD8uQXJ0aWZhY3RzICYmIHRoaXMuQXJ0aWZhY3RMb29rdXBcbiAgICA/IHRoaXMuRW52aXJvbm1lbnQ/LkFydGlmYWN0c1t0aGlzLkFydGlmYWN0TG9va3VwXSB8fCB7fVxuICAgIDoge307XG59XG5cbnB1YmxpYyBnZXQgQXJ0aWZhY3RMb29rdXAoKTogc3RyaW5nIHtcbiAgY29uc3QgYXJ0TG9va3VwID0gdGhpcy5EZXZPcHNBY3Rpb24/LkFydGlmYWN0TG9va3Vwc1xuICAgID8gdGhpcy5EZXZPcHNBY3Rpb24/LkFydGlmYWN0TG9va3Vwc1swXVxuICAgIDogbnVsbDtcblxuICByZXR1cm4gYXJ0TG9va3VwO1xufVxuXG5cblxucHVibGljIGdldCBEZXZPcHNBY3Rpb24oKTogRWFDRGV2T3BzQWN0aW9uIHtcbiAgcmV0dXJuIHRoaXMuRW52aXJvbm1lbnQuRGV2T3BzQWN0aW9ucyAmJiB0aGlzLkRldk9wc0FjdGlvbkxvb2t1cFxuICAgID8gdGhpcy5FbnZpcm9ubWVudC5EZXZPcHNBY3Rpb25zW3RoaXMuRGV2T3BzQWN0aW9uTG9va3VwXSB8fCB7fVxuICAgIDoge307XG59XG5cbkBJbnB1dCgnZGV2b3BzLWFjdGlvbi1sb29rdXAnKVxucHVibGljIERldk9wc0FjdGlvbkxvb2t1cDogc3RyaW5nO1xuXG5wdWJsaWMgZ2V0IERldk9wc0FjdGlvbnMoKTogeyBbbG9va3VwOiBzdHJpbmddOiBFYUNEZXZPcHNBY3Rpb24gfSB7XG4gIHJldHVybiB0aGlzLkVudmlyb25tZW50LkRldk9wc0FjdGlvbnMgfHwge307XG59XG5cblxuXG5wdWJsaWMgRGV2T3BzRm9ybUdyb3VwOiBGb3JtR3JvdXA7XG5cbnB1YmxpYyBnZXQgRWRpdGluZ1NvdXJjZUNvbnRyb2woKTogRWFDU291cmNlQ29udHJvbCB7XG4gICAgbGV0IHNjID0gdGhpcy5FbnZpcm9ubWVudD8uU291cmNlc1xuICAgICAgPyB0aGlzLkVudmlyb25tZW50Py5Tb3VyY2VzW3RoaXMuRWRpdGluZ1NvdXJjZUNvbnRyb2xMb29rdXBdXG4gICAgICA6IG51bGw7XG5cbiAgICBpZiAoc2MgPT0gbnVsbCAmJiB0aGlzLkVkaXRpbmdTb3VyY2VDb250cm9sTG9va3VwKSB7XG4gICAgICBzYyA9IHt9O1xuICAgIH1cblxuICAgIHJldHVybiBzYztcbiAgfVxuXG4gIEBJbnB1dCgnZW52aXJvbm1lbnQnKVxuICBwdWJsaWMgRW52aXJvbm1lbnQ6IEVhQ0Vudmlyb25tZW50QXNDb2RlO1xuXG4gIHB1YmxpYyBFZGl0aW5nU291cmNlQ29udHJvbExvb2t1cDogc3RyaW5nO1xuXG4gIHB1YmxpYyBIb3N0aW5nRGV0YWlsczogUHJvamVjdEhvc3RpbmdEZXRhaWxzO1xuXG4gIEBJbnB1dCgnbWFpbi1icmFuY2gnKVxuICBwdWJsaWMgTWFpbkJyYW5jaDogc3RyaW5nO1xuXG4gIEBJbnB1dCgnb3JnYW5pemF0aW9uJylcbiAgcHVibGljIE9yZ2FuaXphdGlvbjogc3RyaW5nO1xuXG4gIEBJbnB1dCgncmVwb3NpdG9yeScpXG4gIHB1YmxpYyBSZXBvc2l0b3J5OiBzdHJpbmc7XG5cbiAgcHVibGljIGdldCBTb3VyY2VDb250cm9sTG9va3VwcygpOiBBcnJheTxzdHJpbmc+IHtcbiAgICByZXR1cm4gT2JqZWN0LmtleXModGhpcy5Tb3VyY2VDb250cm9scyB8fCB7fSk7XG4gIH1cblxuICBwdWJsaWMgZ2V0IFNvdXJjZUNvbnRyb2xzKCk6IHsgW2xvb2t1cDogc3RyaW5nXTogRWFDU291cmNlQ29udHJvbCB9IHtcbiAgICByZXR1cm4gdGhpcy5FbnZpcm9ubWVudC5Tb3VyY2VzIHx8IHt9O1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIGZvcm1CbGRyOiBGb3JtQnVpbGRlcixcbiAgICBwcm90ZWN0ZWQgYXBwc0Zsb3dTdmM6IEFwcGxpY2F0aW9uc0Zsb3dTZXJ2aWNlKSB7XG4gICAgdGhpcy5Ib3N0aW5nRGV0YWlscyA9IG5ldyBQcm9qZWN0SG9zdGluZ0RldGFpbHMoKTtcbiAgIH1cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgXG4gIH1cblxuLy9BUEkgTUVUSE9EU1xuICBcbi8vSEVMUEVSU1xucHJvdGVjdGVkIGxvYWRQcm9qZWN0SG9zdGluZ0RldGFpbHMoKTogdm9pZCB7XG4gICAgdGhpcy5Ib3N0aW5nRGV0YWlscy5Mb2FkaW5nID0gdHJ1ZTtcblxuICAgIHRoaXMuYXBwc0Zsb3dTdmNcbiAgICAgIC5Mb2FkUHJvamVjdEhvc3RpbmdEZXRhaWxzKFxuICAgICAgICB0aGlzLk9yZ2FuaXphdGlvbixcbiAgICAgICAgdGhpcy5SZXBvc2l0b3J5LFxuICAgICAgICB0aGlzLk1haW5CcmFuY2hcbiAgICAgIClcbiAgICAgIC5zdWJzY3JpYmUoXG4gICAgICAgIChyZXNwb25zZTogQmFzZU1vZGVsZWRSZXNwb25zZTxQcm9qZWN0SG9zdGluZ0RldGFpbHM+KSA9PiB7XG4gICAgICAgICAgdGhpcy5Ib3N0aW5nRGV0YWlscyA9IHJlc3BvbnNlLk1vZGVsO1xuXG4gICAgICAgICAgdGhpcy5Ib3N0aW5nRGV0YWlscy5Mb2FkaW5nID0gZmFsc2U7XG5cbiAgICAgICAgfSxcbiAgICAgICAgKGVycikgPT4ge1xuICAgICAgICAgIHRoaXMuSG9zdGluZ0RldGFpbHMuTG9hZGluZyA9IGZhbHNlO1xuICAgICAgICB9XG4gICAgICApO1xuICBcbn1cbiBcblxufVxuIl19
|
package/esm2015/lib/controls/devops-source-control-form/devops-source-control-form.component.js
CHANGED
|
@@ -1,15 +1,311 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { COMMA, ENTER } from '@angular/cdk/keycodes';
|
|
2
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
3
|
+
import { FormBuilder, FormControl, Validators } from '@angular/forms';
|
|
4
|
+
import { ApplicationsFlowService } from '../../services/applications-flow.service';
|
|
5
|
+
import { ProjectHostingDetails } from '../../state/applications-flow.state';
|
|
2
6
|
export class DevopsSourceControlFormComponent {
|
|
3
|
-
|
|
7
|
+
// Constructors
|
|
8
|
+
constructor(formBuilder, appsFlowSvc) {
|
|
9
|
+
this.formBuilder = formBuilder;
|
|
10
|
+
this.appsFlowSvc = appsFlowSvc;
|
|
11
|
+
this.SeparatorKeysCodes = [ENTER, COMMA];
|
|
12
|
+
this.BuildPath = null;
|
|
13
|
+
this.HostingDetails = new ProjectHostingDetails();
|
|
14
|
+
this.SelectedBranches = [];
|
|
15
|
+
this.SourceControlRoot = '';
|
|
16
|
+
this.UseBranches = true;
|
|
17
|
+
this.UseBuildPath = false;
|
|
18
|
+
}
|
|
19
|
+
// Fields
|
|
20
|
+
// Properties
|
|
21
|
+
get BranchesFormControl() {
|
|
22
|
+
return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'branches');
|
|
23
|
+
}
|
|
24
|
+
get BuildPathFormControl() {
|
|
25
|
+
return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'buildPath');
|
|
26
|
+
}
|
|
27
|
+
get DevOpsActionLookups() {
|
|
28
|
+
return Object.keys(this.DevOpsActions || {});
|
|
29
|
+
}
|
|
30
|
+
get DevOpsActionLookup() {
|
|
31
|
+
var _a, _b, _c;
|
|
32
|
+
if (!!((_a = this.DevOpsActionLookupFormControl) === null || _a === void 0 ? void 0 : _a.value)) {
|
|
33
|
+
return this.DevOpsActionLookupFormControl.value;
|
|
34
|
+
}
|
|
35
|
+
if (!!((_b = this.EditingSourceControl) === null || _b === void 0 ? void 0 : _b.DevOpsActionTriggerLookups)) {
|
|
36
|
+
return (_c = this.EditingSourceControl) === null || _c === void 0 ? void 0 : _c.DevOpsActionTriggerLookups[0];
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
return null;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
get DevOpsActionLookupFormControl() {
|
|
43
|
+
return this.DevOpsSourceControlFormGroup.get('devOpsActionLookup');
|
|
44
|
+
}
|
|
45
|
+
get DevOpsActions() {
|
|
46
|
+
return this.Environment.DevOpsActions || {};
|
|
47
|
+
}
|
|
48
|
+
get EditingSourceControl() {
|
|
49
|
+
var _a, _b;
|
|
50
|
+
let sc = ((_a = this.Environment) === null || _a === void 0 ? void 0 : _a.Sources) ? (_b = this.Environment) === null || _b === void 0 ? void 0 : _b.Sources[this.EditingSourceControlLookup] : null;
|
|
51
|
+
if (sc == null && this.EditingSourceControlLookup) {
|
|
52
|
+
sc = {};
|
|
53
|
+
}
|
|
54
|
+
return sc;
|
|
55
|
+
}
|
|
56
|
+
get MainBranchFormControl() {
|
|
57
|
+
return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'mainBranch');
|
|
58
|
+
}
|
|
59
|
+
get OrganizationFormControl() {
|
|
60
|
+
return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'organization');
|
|
61
|
+
}
|
|
62
|
+
get RepositoryFormControl() {
|
|
63
|
+
return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'repository');
|
|
64
|
+
}
|
|
65
|
+
// Life Cycle
|
|
66
|
+
ngAfterViewInit() { }
|
|
67
|
+
ngOnDestroy() {
|
|
68
|
+
this.destroyFormControls();
|
|
69
|
+
}
|
|
4
70
|
ngOnInit() {
|
|
71
|
+
this.setupFormControls();
|
|
72
|
+
this.RefreshOrganizations();
|
|
73
|
+
}
|
|
74
|
+
// API Methods
|
|
75
|
+
AddBranchOption(event) {
|
|
76
|
+
this.addBranchOption(event.value);
|
|
77
|
+
event.input.value = '';
|
|
78
|
+
}
|
|
79
|
+
BranchOptionSelected(event) {
|
|
80
|
+
this.addBranchOption(event.option.value);
|
|
81
|
+
}
|
|
82
|
+
BranchesChanged(branches) {
|
|
83
|
+
this.loadProjectHostingDetails();
|
|
84
|
+
}
|
|
85
|
+
BuildPathChanged(event) {
|
|
86
|
+
}
|
|
87
|
+
CreateRepository() {
|
|
88
|
+
this.CreatingRepository = true;
|
|
89
|
+
this.RepositoryFormControl.reset();
|
|
90
|
+
}
|
|
91
|
+
CancelCreateRepository() {
|
|
92
|
+
this.CreatingRepository = false;
|
|
93
|
+
}
|
|
94
|
+
DevOpsActionLookupChanged(event) {
|
|
95
|
+
this.configureDevOpsAction();
|
|
96
|
+
}
|
|
97
|
+
MainBranchChanged(event) {
|
|
98
|
+
this.emitBranchesChanged();
|
|
99
|
+
}
|
|
100
|
+
OrganizationChanged(event) {
|
|
101
|
+
const org = this.OrganizationFormControl;
|
|
102
|
+
this.RepositoryFormControl.reset();
|
|
103
|
+
if (this.UseBranches) {
|
|
104
|
+
this.BranchesFormControl.reset();
|
|
105
|
+
this.SelectedBranches = [];
|
|
106
|
+
}
|
|
107
|
+
this.listRepositories();
|
|
108
|
+
}
|
|
109
|
+
RefreshOrganizations() {
|
|
110
|
+
var _a, _b, _c;
|
|
111
|
+
// this.Loading = true;
|
|
112
|
+
this.listOrganizations();
|
|
113
|
+
(_a = this.OrganizationFormControl) === null || _a === void 0 ? void 0 : _a.reset();
|
|
114
|
+
(_b = this.RepositoryFormControl) === null || _b === void 0 ? void 0 : _b.reset();
|
|
115
|
+
if (this.UseBranches) {
|
|
116
|
+
(_c = this.BranchesFormControl) === null || _c === void 0 ? void 0 : _c.reset();
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
RemoveBranchOption(option) {
|
|
120
|
+
const index = this.SelectedBranches.indexOf(option);
|
|
121
|
+
if (index >= 0) {
|
|
122
|
+
this.SelectedBranches.splice(index, 1);
|
|
123
|
+
}
|
|
124
|
+
this.emitBranchesChanged();
|
|
125
|
+
}
|
|
126
|
+
RepositoryChanged(event) {
|
|
127
|
+
const repo = this.RepositoryFormControl;
|
|
128
|
+
if (this.UseBranches) {
|
|
129
|
+
this.BranchesFormControl.reset();
|
|
130
|
+
this.SelectedBranches = [];
|
|
131
|
+
this.listBranches();
|
|
132
|
+
}
|
|
133
|
+
if (!this.UseBranches) {
|
|
134
|
+
this.listBuildPaths();
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
SaveRepository() {
|
|
138
|
+
this.Loading = true;
|
|
139
|
+
const org = this.OrganizationFormControl.value;
|
|
140
|
+
const repoName = this.RepositoryFormControl.value;
|
|
141
|
+
this.appsFlowSvc
|
|
142
|
+
.CreateRepository(org, repoName)
|
|
143
|
+
.subscribe((response) => {
|
|
144
|
+
if (response.Status.Code === 0) {
|
|
145
|
+
this.listRepositories(repoName);
|
|
146
|
+
this.CreatingRepository = false;
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
// TODO: Need to surface an error to the user...
|
|
150
|
+
this.Loading = false;
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
// Helpers
|
|
155
|
+
addBranchOption(value) {
|
|
156
|
+
value = (value || '').trim();
|
|
157
|
+
if (value && this.SelectedBranches.indexOf(value) < 0) {
|
|
158
|
+
this.SelectedBranches.push(value);
|
|
159
|
+
}
|
|
160
|
+
this.BranchesInput.nativeElement.blur();
|
|
161
|
+
this.emitBranchesChanged();
|
|
162
|
+
}
|
|
163
|
+
configureDevOpsAction() {
|
|
164
|
+
setTimeout(() => {
|
|
165
|
+
this.DevOpsActionLookupFormControl.setValue(this.DevOpsActionLookup);
|
|
166
|
+
}, 0);
|
|
167
|
+
}
|
|
168
|
+
destroyFormControls() {
|
|
169
|
+
var _a, _b, _c, _d;
|
|
170
|
+
this.DevOpsSourceControlFormGroup.removeControl([this.SourceControlRoot, 'mainBranch'].join(''));
|
|
171
|
+
(_a = this.DevOpsSourceControlFormGroup) === null || _a === void 0 ? void 0 : _a.removeControl([this.SourceControlRoot, 'branches'].join(''));
|
|
172
|
+
(_b = this.DevOpsSourceControlFormGroup) === null || _b === void 0 ? void 0 : _b.removeControl([this.SourceControlRoot, 'buildPath'].join(''));
|
|
173
|
+
this.SelectedBranches = [];
|
|
174
|
+
(_c = this.DevOpsSourceControlFormGroup) === null || _c === void 0 ? void 0 : _c.removeControl([this.SourceControlRoot, 'organization'].join(''));
|
|
175
|
+
(_d = this.DevOpsSourceControlFormGroup) === null || _d === void 0 ? void 0 : _d.removeControl([this.SourceControlRoot, 'repository'].join(''));
|
|
176
|
+
}
|
|
177
|
+
emitBranchesChanged() {
|
|
178
|
+
var _a, _b;
|
|
179
|
+
if (((_a = this.SelectedBranches) === null || _a === void 0 ? void 0 : _a.length) > 0 &&
|
|
180
|
+
(!this.MainBranchFormControl.value ||
|
|
181
|
+
this.SelectedBranches.indexOf(this.MainBranchFormControl.value) < 0)) {
|
|
182
|
+
this.MainBranchFormControl.setValue(this.SelectedBranches.find((branch) => branch === 'main' || branch === 'master') || this.SelectedBranches[0]);
|
|
183
|
+
}
|
|
184
|
+
else if (((_b = this.SelectedBranches) === null || _b === void 0 ? void 0 : _b.length) <= 0) {
|
|
185
|
+
this.MainBranchFormControl.reset();
|
|
186
|
+
}
|
|
187
|
+
this.BranchesFormControl.setValue(this.SelectedBranches.join(','));
|
|
188
|
+
this.BranchesChanged(this.SelectedBranches || []);
|
|
189
|
+
}
|
|
190
|
+
listBranches() {
|
|
191
|
+
if (this.UseBranches) {
|
|
192
|
+
this.Loading = true;
|
|
193
|
+
this.appsFlowSvc
|
|
194
|
+
.ListBranches(this.OrganizationFormControl.value, this.RepositoryFormControl.value)
|
|
195
|
+
.subscribe((response) => {
|
|
196
|
+
var _a, _b, _c;
|
|
197
|
+
this.BranchOptions = response.Model;
|
|
198
|
+
this.Loading = false;
|
|
199
|
+
if (((_b = (_a = this.EditingSourceControl) === null || _a === void 0 ? void 0 : _a.Branches) === null || _b === void 0 ? void 0 : _b.length) > 0) {
|
|
200
|
+
this.SelectedBranches = this.EditingSourceControl.Branches;
|
|
201
|
+
}
|
|
202
|
+
else if (((_c = this.BranchOptions) === null || _c === void 0 ? void 0 : _c.length) === 1) {
|
|
203
|
+
this.BranchesFormControl.setValue(this.BranchOptions[0].Name);
|
|
204
|
+
this.SelectedBranches = [this.BranchOptions[0].Name];
|
|
205
|
+
}
|
|
206
|
+
this.emitBranchesChanged();
|
|
207
|
+
this.listBuildPaths();
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
listBuildPaths() {
|
|
212
|
+
if (this.UseBuildPath) {
|
|
213
|
+
this.Loading = true;
|
|
214
|
+
this.appsFlowSvc
|
|
215
|
+
.ListBuildPaths(this.OrganizationFormControl.value, this.RepositoryFormControl.value)
|
|
216
|
+
.subscribe((response) => {
|
|
217
|
+
var _a;
|
|
218
|
+
this.BuildPathOptions = response.Model;
|
|
219
|
+
this.Loading = false;
|
|
220
|
+
if (((_a = this.BuildPathOptions) === null || _a === void 0 ? void 0 : _a.length) === 1) {
|
|
221
|
+
this.BuildPathFormControl.setValue(this.BuildPathOptions[0]);
|
|
222
|
+
}
|
|
223
|
+
});
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
listOrganizations() {
|
|
227
|
+
this.Loading = true;
|
|
228
|
+
this.appsFlowSvc
|
|
229
|
+
.ListOrganizations()
|
|
230
|
+
.subscribe((response) => {
|
|
231
|
+
var _a;
|
|
232
|
+
this.OrganizationOptions = response.Model;
|
|
233
|
+
this.Loading = false;
|
|
234
|
+
if ((_a = this.EditingSourceControl) === null || _a === void 0 ? void 0 : _a.Organization) {
|
|
235
|
+
setTimeout(() => {
|
|
236
|
+
var _a;
|
|
237
|
+
this.OrganizationFormControl.setValue(this.EditingSourceControl.Organization);
|
|
238
|
+
this.listRepositories((_a = this.EditingSourceControl) === null || _a === void 0 ? void 0 : _a.Repository);
|
|
239
|
+
}, 0);
|
|
240
|
+
}
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
listRepositories(activeRepo = null) {
|
|
244
|
+
this.Loading = true;
|
|
245
|
+
this.appsFlowSvc
|
|
246
|
+
.ListRepositories(this.OrganizationFormControl.value)
|
|
247
|
+
.subscribe((response) => {
|
|
248
|
+
var _a;
|
|
249
|
+
this.RepositoryOptions = response.Model;
|
|
250
|
+
this.Loading = false;
|
|
251
|
+
if (activeRepo) {
|
|
252
|
+
setTimeout(() => {
|
|
253
|
+
this.RepositoryFormControl.setValue(activeRepo);
|
|
254
|
+
this.listBranches();
|
|
255
|
+
if (!this.UseBranches) {
|
|
256
|
+
this.listBuildPaths();
|
|
257
|
+
}
|
|
258
|
+
}, 0);
|
|
259
|
+
}
|
|
260
|
+
else if (((_a = this.RepositoryOptions) === null || _a === void 0 ? void 0 : _a.length) <= 0) {
|
|
261
|
+
this.CreatingRepository = true;
|
|
262
|
+
}
|
|
263
|
+
});
|
|
264
|
+
}
|
|
265
|
+
loadProjectHostingDetails() {
|
|
266
|
+
var _a, _b, _c, _d;
|
|
267
|
+
if (((_a = this.SelectedBranches) === null || _a === void 0 ? void 0 : _a.length) > 0) {
|
|
268
|
+
this.HostingDetails.Loading = true;
|
|
269
|
+
this.appsFlowSvc
|
|
270
|
+
.LoadProjectHostingDetails((_b = this.OrganizationFormControl) === null || _b === void 0 ? void 0 : _b.value, (_c = this.RepositoryFormControl) === null || _c === void 0 ? void 0 : _c.value, (_d = this.MainBranchFormControl) === null || _d === void 0 ? void 0 : _d.value)
|
|
271
|
+
.subscribe((response) => {
|
|
272
|
+
this.HostingDetails = response.Model;
|
|
273
|
+
this.HostingDetails.Loading = false;
|
|
274
|
+
this.configureDevOpsAction();
|
|
275
|
+
}, (err) => {
|
|
276
|
+
this.HostingDetails.Loading = false;
|
|
277
|
+
});
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
setupFormControls() {
|
|
281
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
|
282
|
+
this.destroyFormControls();
|
|
283
|
+
this.DevOpsSourceControlFormGroup.addControl('devOpsActionLookup', new FormControl(this.DevOpsActionLookup || '', []));
|
|
284
|
+
this.DevOpsSourceControlFormGroup.addControl([this.SourceControlRoot, 'organization'].join(''), new FormControl((_a = this.EditingSourceControl.Organization) !== null && _a !== void 0 ? _a : '', Validators.required));
|
|
285
|
+
this.DevOpsSourceControlFormGroup.addControl([this.SourceControlRoot, 'repository'].join(''), new FormControl((_b = this.EditingSourceControl.Repository) !== null && _b !== void 0 ? _b : '', Validators.required));
|
|
286
|
+
if (this.UseBranches) {
|
|
287
|
+
this.DevOpsSourceControlFormGroup.addControl([this.SourceControlRoot, 'branches'].join(''), new FormControl((_d = (_c = this.EditingSourceControl) === null || _c === void 0 ? void 0 : _c.Branches) !== null && _d !== void 0 ? _d : '', Validators.required));
|
|
288
|
+
this.SelectedBranches = (_e = this.EditingSourceControl) === null || _e === void 0 ? void 0 : _e.Branches;
|
|
289
|
+
this.DevOpsSourceControlFormGroup.addControl([this.SourceControlRoot, 'mainBranch'].join(''), new FormControl((_f = this.EditingSourceControl.MainBranch) !== null && _f !== void 0 ? _f : '', Validators.required));
|
|
290
|
+
}
|
|
291
|
+
if (this.UseBuildPath) {
|
|
292
|
+
this.DevOpsSourceControlFormGroup.addControl([this.SourceControlRoot, 'buildPath'].join(''), new FormControl((_g = this.BuildPath) !== null && _g !== void 0 ? _g : '', Validators.required));
|
|
293
|
+
}
|
|
5
294
|
}
|
|
6
295
|
}
|
|
7
296
|
DevopsSourceControlFormComponent.decorators = [
|
|
8
297
|
{ type: Component, args: [{
|
|
9
298
|
selector: 'lcu-devops-source-control-form',
|
|
10
|
-
template: "<p>devops-source-control-form works!</p>\n",
|
|
299
|
+
template: "<div class=\"form-card\" fxFlex=\"35%\" fxFlex.lt-md=\"100%\">\n <mat-card class=\"spread\">\n <mat-card-header>\n <mat-card-title> Source Control </mat-card-title>\n\n <div fxFlex></div>\n\n <mat-icon\n matSuffix\n matTooltip=\"Configure source control, DevOps CI/CD, and artifacts.\"\n >\n info_outline\n </mat-icon>\n </mat-card-header>\n\n <mat-card-content>\n <div [formGroup]=\"DevOpsSourceControlFormGroup\">\n <div class=\"card\">\n <mat-form-field class=\"mat-full-width\">\n <mat-select\n formControlName=\"devOpsActionLookup\"\n placeholder=\"DevOps Action\"\n [disabled]=\"HostingDetails?.Loading\"\n (selectionChange)=\"DevOpsActionLookupChanged($event)\"\n >\n <ng-container\n *ngFor=\"let devOpsActionLookup of DevOpsActionLookups\"\n >\n <mat-option\n [value]=\"devOpsActionLookup\"\n *ngIf=\"DevOpsActions[devOpsActionLookup]; let devOpsAction\"\n >\n {{ devOpsAction.Name }}\n </mat-option>\n </ng-container>\n \n <mat-option value=\"\">-- Create New --</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n <div class=\"card\" *ngIf=\"OrganizationFormControl?.valid || !Loading\">\n <mat-form-field\n class=\"mat-full-width with-hint\"\n *ngIf=\"OrganizationOptions?.length > 0\"\n >\n <mat-icon class=\"org-icon\" matPrefix>corporate_fare</mat-icon>\n \n <mat-select\n [formControlName]=\"SourceControlRoot + 'organization'\"\n placeholder=\"Organization\"\n (selectionChange)=\"OrganizationChanged($event)\"\n [disabled]=\"Loading || HostingDetails?.Loading\"\n required\n >\n <ng-container *ngFor=\"let orgOpt of OrganizationOptions\">\n <mat-option [value]=\"orgOpt.Name\">\n {{ orgOpt.Name }}\n </mat-option>\n </ng-container>\n </mat-select>\n \n <mat-icon matSuffix (click)=\"RefreshOrganizations()\" matTooltip=\"Refresh Organization\"> refresh </mat-icon>\n \n <a\n matSuffix\n href=\"/.oauth/github?oauth-force-edit=true\"\n target=\"_blank\"\n color=\"accent\"\n >\n <mat-icon color=\"accent\" matTooltip=\"Re-authorize Organizations\"> launch </mat-icon>\n </a>\n \n <mat-hint>\n If you don't have an organization or would like to create a new one,\n <a\n href=\"https://github.com/account/organizations/new\"\n target=\"_blank\"\n >\n start here\n </a>\n </mat-hint>\n </mat-form-field>\n </div>\n \n <div\n class=\"card\"\n *ngIf=\"\n RepositoryFormControl?.valid ||\n (OrganizationFormControl?.valid && !Loading)\n \"\n >\n <mat-form-field class=\"mat-full-width\">\n <mat-icon class=\"org-icon\" matPrefix>description</mat-icon>\n \n <mat-select\n [formControlName]=\"SourceControlRoot + 'repository'\"\n [placeholder]=\"\n OrganizationFormControl?.valid\n ? 'Repository'\n : 'Repository (select organization first)'\n \"\n [disabled]=\"\n !OrganizationFormControl?.valid || Loading || HostingDetails?.Loading\n \"\n (selectionChange)=\"RepositoryChanged($event)\"\n *ngIf=\"!CreatingRepository\"\n required\n >\n <ng-container *ngFor=\"let repoOpt of RepositoryOptions\">\n <mat-option [value]=\"repoOpt.Name\">\n {{ repoOpt.Name }}\n </mat-option>\n </ng-container>\n </mat-select>\n \n <input\n matInput\n placeholder=\"Repository (creates new if does not exist)\"\n [formControlName]=\"SourceControlRoot + 'repository'\"\n *ngIf=\"CreatingRepository\"\n [fxHide]=\"Loading || HostingDetails?.Loading\"\n required\n />\n \n <mat-icon\n matSuffix\n (click)=\"CreateRepository()\"\n [fxHide]=\"Loading || HostingDetails?.Loading\"\n *ngIf=\"!CreatingRepository && OrganizationFormControl?.valid\"\n >\n add_circle\n </mat-icon>\n \n <button mat-button type=\"button\" \n (click)=\"SaveRepository()\" \n *ngIf=\"CreatingRepository && RepositoryFormControl?.valid\">\n \n <mat-icon\n matSuffix\n color=\"primary\"\n >\n save\n </mat-icon>\n </button>\n \n <button mat-button type=\"button\" \n (click)=\"CancelCreateRepository()\"\n *ngIf=\"CreatingRepository\">\n \n <mat-icon\n matSuffix\n \n >\n cancel\n </mat-icon>\n </button>\n </mat-form-field>\n </div>\n \n <div\n class=\"card\"\n *ngIf=\"\n (BranchesFormControl?.valid ||\n (OrganizationFormControl?.valid &&\n RepositoryFormControl?.valid &&\n !Loading)) &&\n !CreatingRepository &&\n UseBranches\n \"\n >\n <mat-form-field class=\"mat-full-width\">\n <mat-icon class=\"org-icon\" matPrefix>account_tree</mat-icon>\n \n <mat-label>Selected Branches</mat-label>\n \n <mat-autocomplete\n (optionSelected)=\"BranchOptionSelected($event)\"\n #branchOptions=\"matAutocomplete\"\n >\n <ng-container *ngFor=\"let branchOpt of BranchOptions\">\n <mat-option [value]=\"branchOpt.Name\">\n {{ branchOpt.Name }}\n </mat-option>\n </ng-container>\n </mat-autocomplete>\n \n <mat-chip-list #selectedBranches>\n <mat-chip\n [removable]=\"true\"\n (removed)=\"RemoveBranchOption(selBranch)\"\n *ngFor=\"let selBranch of SelectedBranches\"\n >\n {{ selBranch }}\n <mat-icon matChipRemove>cancel</mat-icon>\n </mat-chip>\n \n <input\n matInput\n placeholder=\"New Branch...\"\n [formControlName]=\"SourceControlRoot + 'branches'\"\n #branches\n [matAutocomplete]=\"branchOptions\"\n [matChipInputFor]=\"selectedBranches\"\n [matChipInputSeparatorKeyCodes]=\"SeparatorKeysCodes\"\n [matChipInputAddOnBlur]=\"true\"\n (matChipInputTokenEnd)=\"AddBranchOption($event)\"\n [disabled]=\"Loading || HostingDetails?.Loading\"\n required\n />\n </mat-chip-list>\n </mat-form-field>\n \n <mat-form-field\n class=\"mat-full-width with-hint\"\n [fxShow]=\"SelectedBranches?.length > 1\"\n >\n <mat-icon class=\"org-icon\" matPrefix>account_tree</mat-icon>\n \n <mat-select\n [formControlName]=\"SourceControlRoot + 'mainBranch'\"\n placeholder=\"Main Branch\"\n [disabled]=\"Loading || HostingDetails?.Loading\"\n (selectionChange)=\"MainBranchChanged($event)\"\n required\n >\n <ng-container *ngFor=\"let branch of SelectedBranches\">\n <mat-option [value]=\"branch\">\n {{ branch }}\n </mat-option>\n </ng-container>\n </mat-select>\n \n <mat-icon matSuffix (click)=\"RefreshOrganizations()\"> refresh </mat-icon>\n \n <a\n matSuffix\n mat-icon-button\n href=\"/.oauth/github?oauth-force-edit=true\"\n \n target=\"_blank\"\n color=\"accent\"\n >\n <mat-icon\n matTooltip=\"Re-authorize Organizations\"\n color=\"accent\"> launch </mat-icon>\n </a>\n \n <mat-hint>\n If you don't have an organization or would like to create a new one,\n <a\n href=\"https://github.com/account/organizations/new\"\n target=\"_blank\"\n >\n start here\n </a>\n </mat-hint>\n </mat-form-field>\n </div>\n \n <div\n class=\"card\"\n *ngIf=\"\n (BuildPathFormControl?.valid ||\n (OrganizationFormControl?.valid &&\n RepositoryFormControl?.valid &&\n !Loading)) &&\n !CreatingRepository &&\n UseBuildPath\n \"\n >\n <mat-form-field class=\"mat-full-width with-hint\">\n <mat-icon class=\"org-icon\" matPrefix>build</mat-icon>\n \n <mat-select\n [formControlName]=\"SourceControlRoot + 'buildPath'\"\n placeholder=\"Build Path\"\n [disabled]=\"Loading || BuildPathDisabled\"\n (selectionChange)=\"BuildPathChanged($event)\"\n required\n >\n <ng-container *ngFor=\"let buildPath of BuildPathOptions\">\n <mat-option [value]=\"buildPath\">\n {{ buildPath }}\n </mat-option>\n </ng-container>\n </mat-select>\n \n <mat-hint>\n The build path identifies which build action to use for your\n configuration.\n </mat-hint>\n </mat-form-field>\n </div>\n \n <div *ngIf=\"Loading\">\n <div class=\"spread\">\n <lcu-loader style=\"margin: auto\" [loading]=\"true\"></lcu-loader>\n \n <div class=\"margin-3\">\n <h4 class=\"mat-title\" *ngIf=\"!OrganizationFormControl?.valid\">\n Loading organizations\n </h4>\n \n <h4\n class=\"mat-title\"\n *ngIf=\"\n OrganizationFormControl?.valid && !RepositoryFormControl?.valid\n \"\n >\n Loading repositories\n </h4>\n \n <h4\n class=\"mat-title\"\n *ngIf=\"RepositoryFormControl?.valid && !BranchesFormControl?.valid\"\n >\n Loading branches\n </h4>\n \n <h4\n class=\"mat-title\"\n *ngIf=\"\n (RepositoryFormControl?.valid || BranchesFormControl?.valid) &&\n !BuildPathFormControl?.valid\n \"\n >\n Loading build paths\n </h4>\n </div>\n </div>\n </div>\n </div>\n \n </mat-card-content>\n </mat-card>\n </div>\n",
|
|
11
300
|
styles: [""]
|
|
12
301
|
},] }
|
|
13
302
|
];
|
|
14
|
-
DevopsSourceControlFormComponent.ctorParameters = () => [
|
|
15
|
-
|
|
303
|
+
DevopsSourceControlFormComponent.ctorParameters = () => [
|
|
304
|
+
{ type: FormBuilder },
|
|
305
|
+
{ type: ApplicationsFlowService }
|
|
306
|
+
];
|
|
307
|
+
DevopsSourceControlFormComponent.propDecorators = {
|
|
308
|
+
BranchesInput: [{ type: ViewChild, args: ['branches',] }],
|
|
309
|
+
Environment: [{ type: Input, args: ['environment',] }]
|
|
310
|
+
};
|
|
311
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devops-source-control-form.component.js","sourceRoot":"/home/runner/work/applications-flow/applications-flow/projects/common/src/","sources":["lib/controls/devops-source-control-form/devops-source-control-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { COMMA, ENTER } from '@angular/cdk/keycodes';\nimport { AfterViewInit, Component, ElementRef, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { AbstractControl, FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatChipInputEvent } from '@angular/material/chips';\nimport { MatSelectChange } from '@angular/material/select';\nimport { BaseModeledResponse, BaseResponse } from '@lcu/common';\nimport { EaCDevOpsAction, EaCEnvironmentAsCode, EaCSourceControl } from '@semanticjs/common';\nimport { ApplicationsFlowService } from '../../services/applications-flow.service';\nimport { GitHubBranch, GitHubOrganization, GitHubRepository, ProjectHostingDetails } from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-devops-source-control-form',\n  templateUrl: './devops-source-control-form.component.html',\n  styleUrls: ['./devops-source-control-form.component.scss']\n})\nexport class DevopsSourceControlFormComponent \n  implements AfterViewInit, OnDestroy, OnInit\n{\n  //  Fields\n\n  //  Properties\n  public get BranchesFormControl(): AbstractControl {\n    return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'branches');\n  }\n\n\n  @ViewChild('branches')\n  public BranchesInput: ElementRef<HTMLInputElement>;\n\n  public BranchOptions: GitHubBranch[];\n\n  //Optional input not being used setting to \n  // @Input('build-path')\n  public BuildPath: string;\n\n  //Optional not being used\n  // @Input('build-path-disabled')\n  public BuildPathDisabled: boolean;\n\n  public get BuildPathFormControl(): AbstractControl {\n    return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'buildPath');\n  }\n\n  public BuildPathOptions: string[];\n\n  public CreatingRepository: boolean;\n\n\n\n  public get DevOpsActionLookups(): Array<string> {\n    return Object.keys(this.DevOpsActions || {});\n  }\n\n  public get DevOpsActionLookup(): string {\n    if (!!this.DevOpsActionLookupFormControl?.value) {\n      return this.DevOpsActionLookupFormControl.value;\n    }\n\n    if (!!this.EditingSourceControl?.DevOpsActionTriggerLookups) {\n      return this.EditingSourceControl?.DevOpsActionTriggerLookups[0];\n    } else {\n      return null;\n    }\n  }\n\n  public get DevOpsActionLookupFormControl(): AbstractControl {\n    return this.DevOpsSourceControlFormGroup.get('devOpsActionLookup');\n  }\n\n  public get DevOpsActions(): { [lookup: string]: EaCDevOpsAction } {\n    return this.Environment.DevOpsActions || {};\n  }\n\n  public DevOpsSourceControlFormGroup: FormGroup;\n\n  public get EditingSourceControl(): EaCSourceControl {\n    let sc = this.Environment?.Sources\n      ? this.Environment?.Sources[this.EditingSourceControlLookup]\n      : null;\n\n    if (sc == null && this.EditingSourceControlLookup) {\n      sc = {};\n    }\n\n    return sc;\n  }\n\n  public EditingSourceControlLookup: string;\n\n  @Input('environment')\n  public Environment: EaCEnvironmentAsCode;\n\n  public HostingDetails: ProjectHostingDetails;\n\n  public Loading: boolean;\n\n  public get MainBranchFormControl(): AbstractControl {\n    return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'mainBranch');\n  }\n\n  public get OrganizationFormControl(): AbstractControl {\n    return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'organization');\n  }\n\n  public OrganizationOptions: GitHubOrganization[];\n\n  public get RepositoryFormControl(): AbstractControl {\n    return this.DevOpsSourceControlFormGroup.get(this.SourceControlRoot + 'repository');\n  }\n\n  public RepositoryOptions: GitHubRepository[];\n\n  public SelectedBranches: string[];\n\n  public readonly SeparatorKeysCodes = [ENTER, COMMA] as const;\n\n  // this input is not being used anywhere\n  // @Input('source-control-root')\n  public SourceControlRoot: string;\n\n  //not being used set to true by default\n  // @Input('use-branches')\n  public UseBranches: boolean;\n\n  //not being used set to false by default\n  // @Input('use-build-path')\n  public UseBuildPath: boolean;\n\n  //  Constructors\n  constructor(\n    protected formBuilder: FormBuilder,\n    protected appsFlowSvc: ApplicationsFlowService,\n  ) {\n\n    this.BuildPath = null;\n\n    this.HostingDetails = new ProjectHostingDetails();\n\n    this.SelectedBranches = [];\n\n    this.SourceControlRoot = '';\n\n    this.UseBranches = true;\n\n    this.UseBuildPath = false;\n  }\n\n  //  Life Cycle\n  public ngAfterViewInit(): void {}\n\n  public ngOnDestroy(): void {\n    this.destroyFormControls();\n  }\n\n  public ngOnInit(): void {\n    this.setupFormControls();\n\n    this.RefreshOrganizations();\n  }\n\n  //  API Methods\n  public AddBranchOption(event: MatChipInputEvent): void {\n    this.addBranchOption(event.value);\n\n    event.input.value = '';\n  }\n\n  public BranchOptionSelected(event: MatAutocompleteSelectedEvent): void {\n    this.addBranchOption(event.option.value);\n  }\n\n  public BranchesChanged(branches: string[]): void {\n    this.loadProjectHostingDetails();\n  }\n\n  public BuildPathChanged(event: MatSelectChange): void {\n  }\n\n  public CreateRepository(): void {\n    this.CreatingRepository = true;\n\n    this.RepositoryFormControl.reset();\n  }\n\n  public CancelCreateRepository(): void {\n    this.CreatingRepository = false;\n  }\n\n  public DevOpsActionLookupChanged(event: MatSelectChange): void {\n    this.configureDevOpsAction();\n  }\n\n  public MainBranchChanged(event: MatSelectChange): void {\n    this.emitBranchesChanged();\n  }\n\n  public OrganizationChanged(event: MatSelectChange): void {\n    const org = this.OrganizationFormControl;\n\n    this.RepositoryFormControl.reset();\n\n    if (this.UseBranches) {\n      this.BranchesFormControl.reset();\n\n      this.SelectedBranches = [];\n    }\n\n    this.listRepositories();\n  }\n\n  public RefreshOrganizations(): void {\n    // this.Loading = true;\n    this.listOrganizations();\n\n    this.OrganizationFormControl?.reset();\n\n    this.RepositoryFormControl?.reset();\n\n    if (this.UseBranches) {\n      this.BranchesFormControl?.reset();\n    }\n  }\n\n  public RemoveBranchOption(option: string): void {\n    const index = this.SelectedBranches.indexOf(option);\n\n    if (index >= 0) {\n      this.SelectedBranches.splice(index, 1);\n    }\n\n    this.emitBranchesChanged();\n  }\n\n  public RepositoryChanged(event: MatSelectChange): void {\n    const repo = this.RepositoryFormControl;\n\n    if (this.UseBranches) {\n      this.BranchesFormControl.reset();\n\n      this.SelectedBranches = [];\n\n      this.listBranches();\n    }\n\n    if (!this.UseBranches) {\n      this.listBuildPaths();\n    }\n  }\n\n  public SaveRepository(): void {\n    this.Loading = true;\n\n    const org = this.OrganizationFormControl.value;\n\n    const repoName = this.RepositoryFormControl.value;\n\n    this.appsFlowSvc\n      .CreateRepository(org, repoName)\n      .subscribe((response: BaseResponse) => {\n        if (response.Status.Code === 0) {\n          this.listRepositories(repoName);\n\n          this.CreatingRepository = false;\n        } else {\n          //  TODO:  Need to surface an error to the user...\n\n          this.Loading = false;\n        }\n      });\n  }\n\n  //  Helpers\n  protected addBranchOption(value: string): void {\n    value = (value || '').trim();\n\n    if (value && this.SelectedBranches.indexOf(value) < 0) {\n      this.SelectedBranches.push(value);\n    }\n\n    this.BranchesInput.nativeElement.blur();\n\n    this.emitBranchesChanged();\n  }\n\n  protected configureDevOpsAction(): void {\n    setTimeout(() => {\n      this.DevOpsActionLookupFormControl.setValue(this.DevOpsActionLookup);\n    }, 0);\n  }\n\n  protected destroyFormControls(): void {\n    this.DevOpsSourceControlFormGroup.removeControl(\n      [this.SourceControlRoot, 'mainBranch'].join('')\n    );\n\n    this.DevOpsSourceControlFormGroup?.removeControl([this.SourceControlRoot, 'branches'].join(''));\n\n    this.DevOpsSourceControlFormGroup?.removeControl([this.SourceControlRoot, 'buildPath'].join(''));\n\n    this.SelectedBranches = [];\n\n    this.DevOpsSourceControlFormGroup?.removeControl(\n      [this.SourceControlRoot, 'organization'].join('')\n    );\n\n    this.DevOpsSourceControlFormGroup?.removeControl(\n      [this.SourceControlRoot, 'repository'].join('')\n    );\n  }\n\n  protected emitBranchesChanged(): void {\n    if (\n      this.SelectedBranches?.length > 0 &&\n      (!this.MainBranchFormControl.value ||\n        this.SelectedBranches.indexOf(this.MainBranchFormControl.value) < 0)\n    ) {\n      this.MainBranchFormControl.setValue(\n        this.SelectedBranches.find(\n          (branch) => branch === 'main' || branch === 'master'\n        ) || this.SelectedBranches[0]\n      );\n    } else if (this.SelectedBranches?.length <= 0) {\n      this.MainBranchFormControl.reset();\n    }\n\n    this.BranchesFormControl.setValue(this.SelectedBranches.join(','));\n\n    this.BranchesChanged(this.SelectedBranches || []);\n  }\n\n  protected listBranches(): void {\n    if (this.UseBranches) {\n      this.Loading = true;\n\n      this.appsFlowSvc\n        .ListBranches(\n          this.OrganizationFormControl.value,\n          this.RepositoryFormControl.value\n        )\n        .subscribe((response: BaseModeledResponse<GitHubBranch[]>) => {\n          this.BranchOptions = response.Model;\n\n          this.Loading = false;\n\n          if (this.EditingSourceControl?.Branches?.length > 0) {\n            this.SelectedBranches = this.EditingSourceControl.Branches;\n          } else if (this.BranchOptions?.length === 1) {\n            this.BranchesFormControl.setValue(this.BranchOptions[0].Name);\n\n            this.SelectedBranches = [this.BranchOptions[0].Name];\n          }\n\n          this.emitBranchesChanged();\n\n          this.listBuildPaths();\n        });\n    }\n  }\n\n  protected listBuildPaths(): void {\n    if (this.UseBuildPath) {\n      this.Loading = true;\n\n      this.appsFlowSvc\n        .ListBuildPaths(\n          this.OrganizationFormControl.value,\n          this.RepositoryFormControl.value\n        )\n        .subscribe((response: BaseModeledResponse<string[]>) => {\n          this.BuildPathOptions = response.Model;\n\n          this.Loading = false;\n\n          if (this.BuildPathOptions?.length === 1) {\n            this.BuildPathFormControl.setValue(this.BuildPathOptions[0]);\n          }\n        });\n    }\n  }\n\n  protected listOrganizations(): void {\n    this.Loading = true;\n\n    this.appsFlowSvc\n      .ListOrganizations()\n      .subscribe((response: BaseModeledResponse<GitHubOrganization[]>) => {\n        this.OrganizationOptions = response.Model;\n\n        this.Loading = false;\n\n        if (this.EditingSourceControl?.Organization) {\n          setTimeout(() => {\n            this.OrganizationFormControl.setValue(\n              this.EditingSourceControl.Organization\n            );\n\n            this.listRepositories(this.EditingSourceControl?.Repository);\n          }, 0);\n        }\n      });\n  }\n\n  protected listRepositories(activeRepo: string = null): void {\n    this.Loading = true;\n\n    this.appsFlowSvc\n      .ListRepositories(this.OrganizationFormControl.value)\n      .subscribe((response: BaseModeledResponse<GitHubRepository[]>) => {\n        this.RepositoryOptions = response.Model;\n\n        this.Loading = false;\n\n        if (activeRepo) {\n          setTimeout(() => {\n            this.RepositoryFormControl.setValue(activeRepo);\n\n            this.listBranches();\n\n            if (!this.UseBranches) {\n              this.listBuildPaths();\n            }\n          }, 0);\n        } else if (this.RepositoryOptions?.length <= 0) {\n          this.CreatingRepository = true;\n        }\n      });\n  }\n\n  protected loadProjectHostingDetails(): void {\n    if (this.SelectedBranches?.length > 0) {\n      this.HostingDetails.Loading = true;\n\n      this.appsFlowSvc\n        .LoadProjectHostingDetails(\n          this.OrganizationFormControl?.value,\n          this.RepositoryFormControl?.value,\n          this.MainBranchFormControl?.value\n        )\n        .subscribe(\n          (response: BaseModeledResponse<ProjectHostingDetails>) => {\n            this.HostingDetails = response.Model;\n\n            this.HostingDetails.Loading = false;\n\n            this.configureDevOpsAction();\n          },\n          (err) => {\n            this.HostingDetails.Loading = false;\n          }\n        );\n    }\n  }\n\n  protected setupFormControls(): void {\n    this.destroyFormControls();\n\n    this.DevOpsSourceControlFormGroup.addControl(\n      'devOpsActionLookup',\n      new FormControl(this.DevOpsActionLookup || '', [])\n    );\n\n    this.DevOpsSourceControlFormGroup.addControl(\n      [this.SourceControlRoot, 'organization'].join(''),\n      new FormControl(\n        this.EditingSourceControl.Organization ?? '',\n        Validators.required\n      )\n    );\n\n    this.DevOpsSourceControlFormGroup.addControl(\n      [this.SourceControlRoot, 'repository'].join(''),\n      new FormControl(this.EditingSourceControl.Repository ?? '', Validators.required)\n    );\n\n    if (this.UseBranches) {\n      this.DevOpsSourceControlFormGroup.addControl(\n        [this.SourceControlRoot, 'branches'].join(''),\n        new FormControl(this.EditingSourceControl?.Branches ?? '', Validators.required)\n      );\n\n      this.SelectedBranches = this.EditingSourceControl?.Branches;\n\n      this.DevOpsSourceControlFormGroup.addControl(\n        [this.SourceControlRoot, 'mainBranch'].join(''),\n        new FormControl(\n          this.EditingSourceControl.MainBranch ?? '',\n          Validators.required\n        )\n      );\n    }\n\n    if (this.UseBuildPath) {\n      this.DevOpsSourceControlFormGroup.addControl(\n        [this.SourceControlRoot, 'buildPath'].join(''),\n        new FormControl(this.BuildPath ?? '', Validators.required)\n      );\n    }\n  }\n}"]}
|
|
@@ -99,4 +99,4 @@ HostingDetailsFormGroupComponent.propDecorators = {
|
|
|
99
99
|
Organization: [{ type: Input, args: ['organization',] }],
|
|
100
100
|
ParentFormGroup: [{ type: Input, args: ['formGroup',] }]
|
|
101
101
|
};
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hosting-details-form-group.component.js","sourceRoot":"/home/runner/work/applications-flow/applications-flow/projects/common/src/","sources":["lib/elements/projects/controls/hosting-details-form-group/hosting-details-form-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, OnInit } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormGroup,\n  Validators,\n} from '@angular/forms';\nimport { MatRadioChange } from '@angular/material/radio';\nimport { EaCDevOpsAction, EaCArtifact } from '@semanticjs/common';\nimport {\n  ProjectHostingDetails,\n  ProjectHostingOption,\n} from '../../../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-hosting-details-form-group',\n  templateUrl: './hosting-details-form-group.component.html',\n  styleUrls: ['./hosting-details-form-group.component.scss'],\n})\nexport class HostingDetailsFormGroupComponent implements OnChanges, OnInit {\n  //  Fields\n\n  //  Properties\n  @Input('artifact')\n  public Artifact: EaCArtifact;\n\n  @Input('build-pipeline')\n  public BuildPipeline: string;\n\n  public get BuildPipelineFormControl(): AbstractControl {\n    return this.FormGroup.get('buildPipeline');\n  }\n\n  @Input('details')\n  public Details: ProjectHostingDetails;\n\n  @Input('devops-action')\n  public DevOpsAction: EaCDevOpsAction;\n\n  public get DevOpsActionNameFormControl(): AbstractControl {\n    return this.FormGroup.get('devOpsActionName');\n  }\n\n  @Input('disabled')\n  public Disabled: boolean;\n\n  public get FormGroup(): FormGroup {\n    return this.ParentFormGroup.get('hostingDetails') as FormGroup;\n  }\n\n  public get NPMTokenFormControl(): AbstractControl {\n    return this.FormGroup.get('npmToken');\n  }\n\n  @Input('organization')\n  public Organization: string;\n\n  @Input('formGroup')\n  public ParentFormGroup: FormGroup;\n\n  public get SelectedHostingOption(): ProjectHostingOption {\n    return this.Details?.HostingOptions?.find(\n      (ho) => ho.Lookup === this.BuildPipeline\n    );\n  }\n\n  public get SelectedHostingOptionInputControlValues(): {\n    [lookup: string]: any;\n  } {\n    return this.SelectedHostingOption?.Inputs?.reduce((prev, cur) => {\n      const res = {\n        ...prev,\n      };\n\n      res[cur.Lookup] = this.FormGroup.controls[cur.Lookup].value;\n\n      return res;\n    }, {});\n  }\n\n  //  Constructors\n  constructor(protected formBuilder: FormBuilder) {}\n\n  //  Life Cycle\n  public ngOnChanges(): void {}\n\n  public ngOnInit(): void {\n    this.BuildPipeline =\n      this.BuildPipeline || this.Details?.HostingOptions\n        ? this.Details?.HostingOptions[0]?.Lookup\n        : '';\n\n    if (this.FormGroup != null) {\n      this.ParentFormGroup.removeControl('hostingDetails');\n    }\n\n    this.ParentFormGroup.addControl(\n      'hostingDetails',\n      this.formBuilder.group({\n        buildPipeline: [this.BuildPipeline, [Validators.required]],\n      })\n    );\n\n    this.setupControlsForForm();\n  }\n\n  //  API Methods\n  public BuildPipelineChanged(): void {\n    this.BuildPipeline = this.BuildPipelineFormControl.value;\n\n    this.setupControlsForForm();\n  }\n\n  //  Helpers\n  protected setupControlsForForm(): void {\n    for (const ctrlName in this.FormGroup.controls) {\n      if (ctrlName !== 'buildPipeline' && ctrlName !== 'devOpsAction') {\n        this.FormGroup.removeControl(ctrlName);\n      }\n    }\n\n    this.FormGroup.addControl(\n      'devOpsActionName',\n      this.formBuilder.control(\n        this.DevOpsAction?.Name || this.SelectedHostingOption?.Name || '',\n        [Validators.required]\n      )\n    );\n\n    this.SelectedHostingOption?.Inputs?.forEach((input) => {\n      const validators = input.Required ? [Validators.required] : [];\n\n      this.FormGroup.addControl(\n        input.Lookup,\n        this.formBuilder.control(\n          this.Artifact[input.Lookup] || input.DefaultValue || '',\n          validators\n        )\n      );\n\n      // if (this.Disabled) {\n      //   this.FormGroup.controls[input.Lookup].disable();\n      // }\n    });\n\n    if (this.BuildPipelineFormControl.value === 'npm-release') {\n      if (!this.FormGroup.controls.npmToken) {\n        this.FormGroup.addControl(\n          'npmToken',\n          this.formBuilder.control(\n            '',\n            this.Disabled ? [] : [Validators.required]\n          )\n        );\n\n        if (this.Disabled) {\n          this.FormGroup.controls.npmToken.disable();\n        }\n      }\n    } else if (\n      this.BuildPipelineFormControl.value === 'github-artifacts-release'\n    ) {\n      if (this.FormGroup.controls.npmToken) {\n        this.FormGroup.removeControl('npmToken');\n      }\n    }\n  }\n}\n"]}
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hosting-details-form-group.component.js","sourceRoot":"/home/runner/work/applications-flow/applications-flow/projects/common/src/","sources":["lib/elements/projects/controls/hosting-details-form-group/hosting-details-form-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, OnInit } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormGroup,\n  Validators,\n} from '@angular/forms';\nimport { EaCDevOpsAction, EaCArtifact } from '@semanticjs/common';\nimport {\n  ProjectHostingDetails,\n  ProjectHostingOption,\n} from '../../../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-hosting-details-form-group',\n  templateUrl: './hosting-details-form-group.component.html',\n  styleUrls: ['./hosting-details-form-group.component.scss'],\n})\nexport class HostingDetailsFormGroupComponent implements OnChanges, OnInit {\n  //  Fields\n\n  //  Properties\n  @Input('artifact')\n  public Artifact: EaCArtifact;\n\n  @Input('build-pipeline')\n  public BuildPipeline: string;\n\n  public get BuildPipelineFormControl(): AbstractControl {\n    return this.FormGroup.get('buildPipeline');\n  }\n\n  @Input('details')\n  public Details: ProjectHostingDetails;\n\n  @Input('devops-action')\n  public DevOpsAction: EaCDevOpsAction;\n\n  public get DevOpsActionNameFormControl(): AbstractControl {\n    return this.FormGroup.get('devOpsActionName');\n  }\n\n  @Input('disabled')\n  public Disabled: boolean;\n\n  public get FormGroup(): FormGroup {\n    return this.ParentFormGroup.get('hostingDetails') as FormGroup;\n  }\n\n  public get NPMTokenFormControl(): AbstractControl {\n    return this.FormGroup.get('npmToken');\n  }\n\n  @Input('organization')\n  public Organization: string;\n\n  @Input('formGroup')\n  public ParentFormGroup: FormGroup;\n\n  public get SelectedHostingOption(): ProjectHostingOption {\n    return this.Details?.HostingOptions?.find(\n      (ho) => ho.Lookup === this.BuildPipeline\n    );\n  }\n\n  public get SelectedHostingOptionInputControlValues(): {\n    [lookup: string]: any;\n  } {\n    return this.SelectedHostingOption?.Inputs?.reduce((prev, cur) => {\n      const res = {\n        ...prev,\n      };\n\n      res[cur.Lookup] = this.FormGroup.controls[cur.Lookup].value;\n\n      return res;\n    }, {});\n  }\n\n  //  Constructors\n  constructor(protected formBuilder: FormBuilder) {}\n\n  //  Life Cycle\n  public ngOnChanges(): void {}\n\n  public ngOnInit(): void {\n    this.BuildPipeline =\n      this.BuildPipeline || this.Details?.HostingOptions\n        ? this.Details?.HostingOptions[0]?.Lookup\n        : '';\n\n    if (this.FormGroup != null) {\n      this.ParentFormGroup.removeControl('hostingDetails');\n    }\n\n    this.ParentFormGroup.addControl(\n      'hostingDetails',\n      this.formBuilder.group({\n        buildPipeline: [this.BuildPipeline, [Validators.required]],\n      })\n    );\n\n    this.setupControlsForForm();\n  }\n\n  //  API Methods\n  public BuildPipelineChanged(): void {\n    this.BuildPipeline = this.BuildPipelineFormControl.value;\n\n    this.setupControlsForForm();\n  }\n\n  //  Helpers\n  protected setupControlsForForm(): void {\n    for (const ctrlName in this.FormGroup.controls) {\n      if (ctrlName !== 'buildPipeline' && ctrlName !== 'devOpsAction') {\n        this.FormGroup.removeControl(ctrlName);\n      }\n    }\n\n    this.FormGroup.addControl(\n      'devOpsActionName',\n      this.formBuilder.control(\n        this.DevOpsAction?.Name || this.SelectedHostingOption?.Name || '',\n        [Validators.required]\n      )\n    );\n\n    this.SelectedHostingOption?.Inputs?.forEach((input) => {\n      const validators = input.Required ? [Validators.required] : [];\n\n      this.FormGroup.addControl(\n        input.Lookup,\n        this.formBuilder.control(\n          this.Artifact[input.Lookup] || input.DefaultValue || '',\n          validators\n        )\n      );\n\n      // if (this.Disabled) {\n      //   this.FormGroup.controls[input.Lookup].disable();\n      // }\n    });\n\n    if (this.BuildPipelineFormControl.value === 'npm-release') {\n      if (!this.FormGroup.controls.npmToken) {\n        this.FormGroup.addControl(\n          'npmToken',\n          this.formBuilder.control(\n            '',\n            this.Disabled ? [] : [Validators.required]\n          )\n        );\n\n        if (this.Disabled) {\n          this.FormGroup.controls.npmToken.disable();\n        }\n      }\n    } else if (\n      this.BuildPipelineFormControl.value === 'github-artifacts-release'\n    ) {\n      if (this.FormGroup.controls.npmToken) {\n        this.FormGroup.removeControl('npmToken');\n      }\n    }\n  }\n}\n"]}
|