@lowcodeunit/applications-flow-common 1.37.180-merge → 1.37.181-integration

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.
@@ -83,19 +83,19 @@ export class BuildPipelineFormComponent {
83
83
  SaveEnvironment() {
84
84
  const saveEnvReq = {
85
85
  Environment: {
86
- // ...this.Environment,
86
+ ...this.Environment,
87
87
  Artifacts: this.Environment.Artifacts || {},
88
- // DevOpsActions: this.Environment.DevOpsActions || {},
89
- // Secrets: this.Environment.Secrets || {},
90
- // Sources: this.Environment.Sources || {},
88
+ DevOpsActions: this.Environment.DevOpsActions || {},
89
+ Secrets: this.Environment.Secrets || {},
90
+ Sources: this.Environment.Sources || {},
91
91
  },
92
- // EnvironmentLookup: this.EnvironmentLookup,
93
- // EnterpriseDataTokens: {},
92
+ EnvironmentLookup: this.EnvironmentLookup,
93
+ EnterpriseDataTokens: {},
94
94
  };
95
95
  let artifactLookup;
96
96
  let artifact = {
97
- // ...this.Artifact,
98
- // ...this.SelectedHostingOptionInputControlValues,
97
+ ...this.Artifact,
98
+ ...this.SelectedHostingOptionInputControlValues,
99
99
  };
100
100
  if (!this.ArtifactLookup) {
101
101
  artifactLookup = Guid.CreateRaw();
@@ -123,14 +123,14 @@ export class BuildPipelineFormComponent {
123
123
  if (this.NPMTokenFormControl?.value) {
124
124
  const secretLookup = 'npm-access-token';
125
125
  doa.SecretLookups = [secretLookup];
126
- if (!saveEnvReq.Environment.Secrets[secretLookup]) {
127
- saveEnvReq.Environment.Secrets[secretLookup] = {
128
- Name: 'NPM Access Token',
129
- DataTokenLookup: secretLookup,
130
- KnownAs: 'NPM_TOKEN',
131
- };
132
- }
126
+ saveEnvReq.Environment.Secrets[secretLookup] = {
127
+ Name: 'NPM Access Token',
128
+ DataTokenLookup: secretLookup,
129
+ KnownAs: 'NPM_TOKEN',
130
+ };
133
131
  saveEnvReq.EnterpriseDataTokens[secretLookup] = {
132
+ Name: saveEnvReq.Environment.Secrets[secretLookup].Name,
133
+ Description: saveEnvReq.Environment.Secrets[secretLookup].Name,
134
134
  Value: this.NPMTokenFormControl.value,
135
135
  };
136
136
  }
@@ -144,7 +144,6 @@ export class BuildPipelineFormComponent {
144
144
  };
145
145
  saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;
146
146
  }
147
- console.log('env req: ', saveEnvReq);
148
147
  this.eacSvc.SaveEnvironmentAsCode(saveEnvReq).then((res) => {
149
148
  this.ResponseEvent.emit(res);
150
149
  });
@@ -241,4 +240,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
241
240
  type: Output,
242
241
  args: ['response-event']
243
242
  }] } });
244
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-pipeline-form.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/controls/build-pipeline-form/build-pipeline-form.component.ts","../../../../../../projects/common/src/lib/controls/build-pipeline-form/build-pipeline-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n    AbstractControl,\n    FormBuilder,\n    FormGroup,\n    Validators,\n} from '@angular/forms';\nimport { BaseModeledResponse, Guid } from '@lcu/common';\nimport {\n    EaCArtifact,\n    EaCDevOpsAction,\n    EaCEnvironmentAsCode,\n} from '@semanticjs/common';\nimport { ApplicationsFlowService } from '../../services/applications-flow.service';\nimport {\n    EaCService,\n    SaveEnvironmentAsCodeEventRequest,\n} from '../../services/eac.service';\nimport {\n    ProjectHostingDetails,\n    ProjectHostingOption,\n} from '../../state/applications-flow.state';\n\n@Component({\n    selector: 'lcu-build-pipeline-form',\n    templateUrl: './build-pipeline-form.component.html',\n    styleUrls: ['./build-pipeline-form.component.scss'],\n})\nexport class BuildPipelineFormComponent implements OnInit {\n    //PROPERTIES\n\n    // @Input('build-pipeline')\n    public BuildPipeline: string;\n\n    @Input('devops-action-lookup')\n    public DevOpsActionLookup: string;\n\n    @Input('disabled')\n    public Disabled: boolean;\n\n    @Input('environment')\n    public Environment: EaCEnvironmentAsCode;\n\n    @Input('environment-lookup')\n    public EnvironmentLookup: string;\n\n    // @Input('hosting-details')\n    public HostingDetails: ProjectHostingDetails;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Output('response-event')\n    public ResponseEvent: EventEmitter<any>;\n\n    protected get Artifact(): EaCArtifact {\n        // console.log(\"ARTIFACT: \", this.Environment?.Artifacts[this.ArtifactLookup]);\n        return this.Environment?.Artifacts && this.ArtifactLookup\n            ? this.Environment?.Artifacts[this.ArtifactLookup] || {}\n            : {};\n    }\n\n    protected get ArtifactLookup(): string {\n        const artLookup = this.DevOpsAction?.ArtifactLookups\n            ? this.DevOpsAction?.ArtifactLookups[0]\n            : null;\n\n        return artLookup;\n    }\n\n    public get BuildPipelineFormControl(): AbstractControl {\n        return this.BuildPipelineFormGroup?.get('buildPipeline');\n    }\n\n    protected get DevOpsAction(): EaCDevOpsAction {\n        return this.Environment.DevOpsActions && this.DevOpsActionLookup\n            ? this.Environment.DevOpsActions[this.DevOpsActionLookup] || {}\n            : {};\n    }\n\n    protected get DevOpsActions(): { [lookup: string]: EaCDevOpsAction } {\n        return this.Environment.DevOpsActions || {};\n    }\n\n    public get DevOpsActionNameFormControl(): AbstractControl {\n        return this.BuildPipelineFormGroup.get('devOpsActionName');\n    }\n\n    public get NPMTokenFormControl(): AbstractControl {\n        return this.BuildPipelineFormGroup.get('npmToken');\n    }\n\n    protected get SelectedHostingOptionInputControlValues(): {\n        [lookup: string]: any;\n    } {\n        return this.SelectedHostingOption?.Inputs?.reduce((prev, cur) => {\n            const res: any = {\n                ...prev,\n            };\n\n            res[cur.Lookup] =\n                this.BuildPipelineFormGroup.controls[cur.Lookup].value;\n\n            return res;\n        }, {});\n    }\n\n    // public DevOpsAction: EaCDevOpsAction;\n\n    // public DevOpsActions: { [lookup: string]: EaCDevOpsAction };\n\n    public BuildPipelineFormGroup: FormGroup;\n\n    // public SelectedHostingOptionInputControlValues: {\n    //     [lookup: string]: any;\n    // };\n\n    public SelectedHostingOption: ProjectHostingOption;\n\n    constructor(\n        protected eacSvc: EaCService,\n        protected formBuilder: FormBuilder,\n        protected appsFlowSvc: ApplicationsFlowService\n    ) {\n        this.Disabled = false;\n        this.HostingDetails = new ProjectHostingDetails();\n        this.ResponseEvent = new EventEmitter();\n    }\n\n    public ngOnInit(): void {\n        this.BuildPipelineFormGroup = this.formBuilder.group({});\n\n        this.loadProjectHostingDetails();\n    }\n\n    public ngOnChanges() {\n        this.loadProjectHostingDetails();\n    }\n\n    //API METHODS\n\n    public BuildPipelineChanged(): void {\n        //for some reason this value is coming back undefined\n        // console.log(\"build pipeline value: \", this.BuildPipelineFormControl?.value)\n        this.BuildPipeline = this.BuildPipelineFormControl?.value;\n        // this.loadProjectHostingDetails();\n\n        this.setupControlsForForm();\n    }\n\n    public SubmitBuildPipeline() {\n        // console.log(\"submitting build pipeline: \", this.BuildPipelineFormGroup.value);\n        this.SaveEnvironment();\n    }\n\n    public SaveEnvironment(): void {\n        const saveEnvReq: SaveEnvironmentAsCodeEventRequest = {\n            Environment: {\n                // ...this.Environment,\n                Artifacts: this.Environment.Artifacts || {},\n                // DevOpsActions: this.Environment.DevOpsActions || {},\n                // Secrets: this.Environment.Secrets || {},\n                // Sources: this.Environment.Sources || {},\n            },\n            // EnvironmentLookup: this.EnvironmentLookup,\n            // EnterpriseDataTokens: {},\n        };\n\n        let artifactLookup: string;\n\n        let artifact: EaCArtifact = {\n            // ...this.Artifact,\n            // ...this.SelectedHostingOptionInputControlValues,\n        };\n\n        if (!this.ArtifactLookup) {\n            artifactLookup = Guid.CreateRaw();\n\n            artifact = {\n                ...artifact,\n                Type: this.SelectedHostingOption.ArtifactType,\n                Name: this.SelectedHostingOption.Name,\n                NPMRegistry: 'https://registry.npmjs.org/',\n            };\n        } else {\n            artifactLookup = this.ArtifactLookup;\n        }\n\n        saveEnvReq.Environment.Artifacts[artifactLookup] = artifact;\n\n        let devOpsActionLookup: string;\n\n        if (!this.DevOpsActionLookup) {\n            devOpsActionLookup = Guid.CreateRaw();\n\n            const doa: EaCDevOpsAction = {\n                ...this.DevOpsAction,\n                ArtifactLookups: [artifactLookup],\n                Name: this.DevOpsActionNameFormControl.value,\n                Path: this.SelectedHostingOption.Path,\n                Templates: this.SelectedHostingOption.Templates,\n            };\n\n            if (this.NPMTokenFormControl?.value) {\n                const secretLookup = 'npm-access-token';\n\n                doa.SecretLookups = [secretLookup];\n\n                if (!saveEnvReq.Environment.Secrets[secretLookup]) {\n                    saveEnvReq.Environment.Secrets[secretLookup] = {\n                        Name: 'NPM Access Token',\n                        DataTokenLookup: secretLookup,\n                        KnownAs: 'NPM_TOKEN',\n                    };\n                }\n\n                saveEnvReq.EnterpriseDataTokens[secretLookup] = {\n                    Value: this.NPMTokenFormControl.value,\n                };\n            }\n\n            saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;\n        } else {\n            devOpsActionLookup = this.DevOpsActionLookup;\n\n            const doa: EaCDevOpsAction = {\n                ...this.DevOpsAction,\n                Name: this.DevOpsActionNameFormControl.value,\n            };\n\n            saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;\n        }\n        console.log('env req: ', saveEnvReq);\n\n        this.eacSvc.SaveEnvironmentAsCode(saveEnvReq).then((res) => {\n            this.ResponseEvent.emit(res);\n        });\n    }\n\n    //  Helpers\n\n    protected getSelectedHostingOption() {\n        this.SelectedHostingOption = this.HostingDetails?.HostingOptions?.find(\n            (ho) => ho.Lookup === this.BuildPipeline\n        );\n    }\n    protected setupControlsForForm(): void {\n        this.getSelectedHostingOption();\n\n        // this.BuildPipeline =\n        //         this.BuildPipeline || this.HostingDetails?.HostingOptions\n        //           ? this.HostingDetails?.HostingOptions[0]?.Lookup\n        //           : '';\n\n        // console.log(\"hosting details: \", this.HostingDetails)\n\n        for (const ctrlName in this.BuildPipelineFormGroup.controls) {\n            //devOpsAction doesn't exist\n            //removes hosting details\n            if (ctrlName !== 'buildPipeline' && ctrlName !== 'devOpsAction') {\n                // console.log(\"removing control: \", ctrlName)\n                this.BuildPipelineFormGroup.removeControl(ctrlName);\n            }\n        }\n\n        this.BuildPipelineFormGroup.addControl(\n            'buildPipeline',\n            this.formBuilder.control(this.BuildPipeline || '', [\n                Validators.required,\n            ])\n        );\n\n        this.BuildPipelineFormGroup.addControl(\n            'devOpsActionName',\n            this.formBuilder.control(\n                this.DevOpsAction?.Name ||\n                    this.SelectedHostingOption?.Name ||\n                    '',\n                [Validators.required]\n            )\n        );\n\n        // console.log(\"selected hosting options: \", this.SelectedHostingOption?.Inputs);\n\n        this.SelectedHostingOption?.Inputs?.forEach((input) => {\n            const validators = input.Required ? [Validators.required] : [];\n\n            this.BuildPipelineFormGroup.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            // console.log('npm release');\n            if (!this.BuildPipelineFormGroup?.controls?.npmToken) {\n                // console.log('npm token if');\n                this.BuildPipelineFormGroup.addControl(\n                    'npmToken',\n                    this.formBuilder.control(\n                        '',\n                        this.Disabled ? [] : [Validators.required]\n                    )\n                );\n\n                if (this.Disabled) {\n                    this.BuildPipelineFormGroup.controls.npmToken.disable();\n                }\n            }\n        } else if (\n            this.BuildPipelineFormControl?.value === 'github-artifacts-release'\n        ) {\n            if (this.BuildPipelineFormGroup?.controls?.npmToken) {\n                this.BuildPipelineFormGroup.removeControl('npmToken');\n            }\n        }\n    }\n\n    protected loadProjectHostingDetails(): void {\n        this.HostingDetails.Loading = true;\n        this.appsFlowSvc.LoadProjectHostingDetails().subscribe(\n            (response: BaseModeledResponse<ProjectHostingDetails>) => {\n                this.HostingDetails = response.Model;\n                // console.log('response: ', response);\n                this.HostingDetails.Loading = false;\n\n                // console.log(' DevOpsAction.Path: ', this.DevOpsAction.Path);\n\n                const hostOption = this.HostingDetails?.HostingOptions?.find(\n                    (ho) => ho.Path === this.DevOpsAction.Path\n                );\n\n                this.BuildPipeline = hostOption?.Lookup;\n                // this.SelectedHostingOption = hostOption;\n\n                // console.log(\"Build Pipeline HERE= \", this.BuildPipeline);\n\n                this.setupControlsForForm();\n            },\n            (err) => {\n                console.log('ERR: ', err);\n                this.HostingDetails.Loading = false;\n            }\n        );\n        // console.log('HOSTING DETAILS: ', this.HostingDetails);\n    }\n}\n","<form\n    class=\"form-card\"\n    [formGroup]=\"BuildPipelineFormGroup\"\n    (ngSubmit)=\"SubmitBuildPipeline()\"\n>\n    <ng-container *ngIf=\"HostingDetails?.Loading || Loading\">\n        <skeleton-block class=\"s-block\" effect=\"wave\"></skeleton-block>\n\n        <skeleton-block class=\"s-block\" effect=\"wave\"></skeleton-block>\n\n        <ng-container *ngIf=\"SelectedHostingOption?.Inputs\">\n            <ng-container\n                *ngFor=\"let hostOption of HostingDetails?.HostingOptions\"\n            >\n                <skeleton-block class=\"s-block\" effect=\"wave\"></skeleton-block>\n            </ng-container>\n        </ng-container>\n\n        <skeleton-block *ngIf=\"\" class=\"s-block\" effect=\"wave\"></skeleton-block>\n    </ng-container>\n\n    <ng-container *ngIf=\"!HostingDetails?.Loading && !Loading\">\n        <!-- <div  *ngIf=\"!HostingDetails?.Loading\"> -->\n        <mat-form-field class=\"mat-full-width\">\n            <mat-select\n                formControlName=\"buildPipeline\"\n                placeholder=\"Build Pipeline\"\n                [disabled]=\"Disabled\"\n                (selectionChange)=\"BuildPipelineChanged()\"\n                required\n            >\n                <ng-container\n                    *ngFor=\"\n                        let hostOption of HostingDetails?.HostingOptions;\n                        let i = index\n                    \"\n                >\n                    <mat-option [value]=\"hostOption.Lookup\">\n                        {{ hostOption.Name }}\n                    </mat-option>\n                </ng-container>\n            </mat-select>\n\n            <mat-hint>\n                <ng-container\n                    *ngFor=\"let hostOption of HostingDetails?.HostingOptions\"\n                >\n                    <span *ngIf=\"BuildPipeline == hostOption?.Lookup\">\n                        {{ hostOption.Description }}\n                    </span>\n                </ng-container>\n            </mat-hint>\n        </mat-form-field>\n\n        <mat-form-field class=\"mat-full-width\">\n            <input\n                matInput\n                formControlName=\"devOpsActionName\"\n                placeholder=\"Name of DevOps Action\"\n                required=\"true\"\n            />\n        </mat-form-field>\n\n        <ng-container *ngFor=\"let input of SelectedHostingOption?.Inputs\">\n            <mat-form-field class=\"mat-full-width\">\n                <input\n                    matInput\n                    [formControlName]=\"input.Lookup\"\n                    [placeholder]=\"input.Placeholder\"\n                    [required]=\"input.Required\"\n                />\n\n                <mat-hint>{{ input.Hint }}</mat-hint>\n            </mat-form-field>\n        </ng-container>\n\n        <div *ngIf=\"BuildPipeline == 'npm-release'\">\n            <mat-form-field class=\"mat-full-width with-hint padding-bottom-4\">\n                <mat-icon matPrefix>security</mat-icon>\n\n                <input\n                    id=\"npm-token\"\n                    matInput\n                    type=\"text\"\n                    formControlName=\"npmToken\"\n                    placeholder=\"NPM token\"\n                    [required]=\"!Disabled\"\n                    style=\"-webkit-text-security: disc\"\n                />\n                <mat-hint>\n                    Securely publish to NPM, provide an NPM Personal Access\n                    Token (PAT) with publish access to the organization used for\n                    your NPM packages. Learn how to create and view access\n                    tokens\n                    <a\n                        href=\"https://docs.npmjs.com/creating-and-viewing-access-tokens\"\n                        target=\"_blank\"\n                        class=\"primary-link\"\n                    >\n                        here.\n                    </a>\n                </mat-hint>\n            </mat-form-field>\n        </div>\n        <!-- </div> -->\n\n        <!-- <div *ngIf=\"HostingDetails?.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\">Loading hosting details</h4>\n              </div>\n            </div>\n          </div> -->\n    </ng-container>\n    <!-- </mat-card-content> -->\n\n    <!-- <mat-card-actions fxLayoutAlign=\"center center\"> -->\n\n    <!-- <button \n          *ngIf=\"!Loading\"\n          mat-raised-button \n          type=\"submit\" \n          fxFlex=\"100%\" \n          color=\"primary\" \n          [disabled]=\"!BuildPipelineFormGroup.valid || !BuildPipelineFormGroup.dirty\">\n          <mat-icon>save</mat-icon>\n          Save Build Pipeline\n        </button> -->\n    <!-- <lcu-loader [loading]=\"Loading\"></lcu-loader>   -->\n\n    <!-- </mat-card-actions> -->\n    <!-- </mat-card> -->\n</form>\n"]}
243
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-pipeline-form.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/controls/build-pipeline-form/build-pipeline-form.component.ts","../../../../../../projects/common/src/lib/controls/build-pipeline-form/build-pipeline-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n    AbstractControl,\n    FormBuilder,\n    FormGroup,\n    Validators,\n} from '@angular/forms';\nimport { BaseModeledResponse, Guid } from '@lcu/common';\nimport {\n    EaCArtifact,\n    EaCDevOpsAction,\n    EaCEnvironmentAsCode,\n} from '@semanticjs/common';\nimport { ApplicationsFlowService } from '../../services/applications-flow.service';\nimport {\n    EaCService,\n    SaveEnvironmentAsCodeEventRequest,\n} from '../../services/eac.service';\nimport {\n    ProjectHostingDetails,\n    ProjectHostingOption,\n} from '../../state/applications-flow.state';\n\n@Component({\n    selector: 'lcu-build-pipeline-form',\n    templateUrl: './build-pipeline-form.component.html',\n    styleUrls: ['./build-pipeline-form.component.scss'],\n})\nexport class BuildPipelineFormComponent implements OnInit {\n    //PROPERTIES\n\n    // @Input('build-pipeline')\n    public BuildPipeline: string;\n\n    @Input('devops-action-lookup')\n    public DevOpsActionLookup: string;\n\n    @Input('disabled')\n    public Disabled: boolean;\n\n    @Input('environment')\n    public Environment: EaCEnvironmentAsCode;\n\n    @Input('environment-lookup')\n    public EnvironmentLookup: string;\n\n    // @Input('hosting-details')\n    public HostingDetails: ProjectHostingDetails;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Output('response-event')\n    public ResponseEvent: EventEmitter<any>;\n\n    protected get Artifact(): EaCArtifact {\n        // console.log(\"ARTIFACT: \", this.Environment?.Artifacts[this.ArtifactLookup]);\n        return this.Environment?.Artifacts && this.ArtifactLookup\n            ? this.Environment?.Artifacts[this.ArtifactLookup] || {}\n            : {};\n    }\n\n    protected get ArtifactLookup(): string {\n        const artLookup = this.DevOpsAction?.ArtifactLookups\n            ? this.DevOpsAction?.ArtifactLookups[0]\n            : null;\n\n        return artLookup;\n    }\n\n    public get BuildPipelineFormControl(): AbstractControl {\n        return this.BuildPipelineFormGroup?.get('buildPipeline');\n    }\n\n    protected get DevOpsAction(): EaCDevOpsAction {\n        return this.Environment.DevOpsActions && this.DevOpsActionLookup\n            ? this.Environment.DevOpsActions[this.DevOpsActionLookup] || {}\n            : {};\n    }\n\n    protected get DevOpsActions(): { [lookup: string]: EaCDevOpsAction } {\n        return this.Environment.DevOpsActions || {};\n    }\n\n    public get DevOpsActionNameFormControl(): AbstractControl {\n        return this.BuildPipelineFormGroup.get('devOpsActionName');\n    }\n\n    public get NPMTokenFormControl(): AbstractControl {\n        return this.BuildPipelineFormGroup.get('npmToken');\n    }\n\n    protected get SelectedHostingOptionInputControlValues(): {\n        [lookup: string]: any;\n    } {\n        return this.SelectedHostingOption?.Inputs?.reduce((prev, cur) => {\n            const res: any = {\n                ...prev,\n            };\n\n            res[cur.Lookup] =\n                this.BuildPipelineFormGroup.controls[cur.Lookup].value;\n\n            return res;\n        }, {});\n    }\n\n    // public DevOpsAction: EaCDevOpsAction;\n\n    // public DevOpsActions: { [lookup: string]: EaCDevOpsAction };\n\n    public BuildPipelineFormGroup: FormGroup;\n\n    // public SelectedHostingOptionInputControlValues: {\n    //     [lookup: string]: any;\n    // };\n\n    public SelectedHostingOption: ProjectHostingOption;\n\n    constructor(\n        protected eacSvc: EaCService,\n        protected formBuilder: FormBuilder,\n        protected appsFlowSvc: ApplicationsFlowService\n    ) {\n        this.Disabled = false;\n        this.HostingDetails = new ProjectHostingDetails();\n        this.ResponseEvent = new EventEmitter();\n    }\n\n    public ngOnInit(): void {\n        this.BuildPipelineFormGroup = this.formBuilder.group({});\n\n        this.loadProjectHostingDetails();\n    }\n\n    public ngOnChanges() {\n        this.loadProjectHostingDetails();\n    }\n\n    //API METHODS\n\n    public BuildPipelineChanged(): void {\n        //for some reason this value is coming back undefined\n        // console.log(\"build pipeline value: \", this.BuildPipelineFormControl?.value)\n        this.BuildPipeline = this.BuildPipelineFormControl?.value;\n        // this.loadProjectHostingDetails();\n\n        this.setupControlsForForm();\n    }\n\n    public SubmitBuildPipeline() {\n        // console.log(\"submitting build pipeline: \", this.BuildPipelineFormGroup.value);\n        this.SaveEnvironment();\n    }\n\n    public SaveEnvironment(): void {\n        const saveEnvReq: SaveEnvironmentAsCodeEventRequest = {\n            Environment: {\n                ...this.Environment,\n                Artifacts: this.Environment.Artifacts || {},\n                DevOpsActions: this.Environment.DevOpsActions || {},\n                Secrets: this.Environment.Secrets || {},\n                Sources: this.Environment.Sources || {},\n            },\n            EnvironmentLookup: this.EnvironmentLookup,\n            EnterpriseDataTokens: {},\n        };\n\n        let artifactLookup: string;\n\n        let artifact: EaCArtifact = {\n            ...this.Artifact,\n            ...this.SelectedHostingOptionInputControlValues,\n        };\n\n        if (!this.ArtifactLookup) {\n            artifactLookup = Guid.CreateRaw();\n\n            artifact = {\n                ...artifact,\n                Type: this.SelectedHostingOption.ArtifactType,\n                Name: this.SelectedHostingOption.Name,\n                NPMRegistry: 'https://registry.npmjs.org/',\n            };\n        } else {\n            artifactLookup = this.ArtifactLookup;\n        }\n\n        saveEnvReq.Environment.Artifacts[artifactLookup] = artifact;\n\n        let devOpsActionLookup: string;\n\n        if (!this.DevOpsActionLookup) {\n            devOpsActionLookup = Guid.CreateRaw();\n\n            const doa: EaCDevOpsAction = {\n                ...this.DevOpsAction,\n                ArtifactLookups: [artifactLookup],\n                Name: this.DevOpsActionNameFormControl.value,\n                Path: this.SelectedHostingOption.Path,\n                Templates: this.SelectedHostingOption.Templates,\n            };\n\n            if (this.NPMTokenFormControl?.value) {\n                const secretLookup = 'npm-access-token';\n\n                doa.SecretLookups = [secretLookup];\n\n                saveEnvReq.Environment.Secrets[secretLookup] = {\n                    Name: 'NPM Access Token',\n                    DataTokenLookup: secretLookup,\n                    KnownAs: 'NPM_TOKEN',\n                };\n\n                saveEnvReq.EnterpriseDataTokens[secretLookup] = {\n                    Name: saveEnvReq.Environment.Secrets[secretLookup].Name,\n                    Description:\n                        saveEnvReq.Environment.Secrets[secretLookup].Name,\n                    Value: this.NPMTokenFormControl.value,\n                };\n            }\n\n            saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;\n        } else {\n            devOpsActionLookup = this.DevOpsActionLookup;\n\n            const doa: EaCDevOpsAction = {\n                ...this.DevOpsAction,\n                Name: this.DevOpsActionNameFormControl.value,\n            };\n\n            saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;\n        }\n\n        this.eacSvc.SaveEnvironmentAsCode(saveEnvReq).then((res) => {\n            this.ResponseEvent.emit(res);\n        });\n    }\n\n    //  Helpers\n\n    protected getSelectedHostingOption() {\n        this.SelectedHostingOption = this.HostingDetails?.HostingOptions?.find(\n            (ho) => ho.Lookup === this.BuildPipeline\n        );\n    }\n    protected setupControlsForForm(): void {\n        this.getSelectedHostingOption();\n\n        // this.BuildPipeline =\n        //         this.BuildPipeline || this.HostingDetails?.HostingOptions\n        //           ? this.HostingDetails?.HostingOptions[0]?.Lookup\n        //           : '';\n\n        // console.log(\"hosting details: \", this.HostingDetails)\n\n        for (const ctrlName in this.BuildPipelineFormGroup.controls) {\n            //devOpsAction doesn't exist\n            //removes hosting details\n            if (ctrlName !== 'buildPipeline' && ctrlName !== 'devOpsAction') {\n                // console.log(\"removing control: \", ctrlName)\n                this.BuildPipelineFormGroup.removeControl(ctrlName);\n            }\n        }\n\n        this.BuildPipelineFormGroup.addControl(\n            'buildPipeline',\n            this.formBuilder.control(this.BuildPipeline || '', [\n                Validators.required,\n            ])\n        );\n\n        this.BuildPipelineFormGroup.addControl(\n            'devOpsActionName',\n            this.formBuilder.control(\n                this.DevOpsAction?.Name ||\n                    this.SelectedHostingOption?.Name ||\n                    '',\n                [Validators.required]\n            )\n        );\n\n        // console.log(\"selected hosting options: \", this.SelectedHostingOption?.Inputs);\n\n        this.SelectedHostingOption?.Inputs?.forEach((input) => {\n            const validators = input.Required ? [Validators.required] : [];\n\n            this.BuildPipelineFormGroup.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            // console.log('npm release');\n            if (!this.BuildPipelineFormGroup?.controls?.npmToken) {\n                // console.log('npm token if');\n                this.BuildPipelineFormGroup.addControl(\n                    'npmToken',\n                    this.formBuilder.control(\n                        '',\n                        this.Disabled ? [] : [Validators.required]\n                    )\n                );\n\n                if (this.Disabled) {\n                    this.BuildPipelineFormGroup.controls.npmToken.disable();\n                }\n            }\n        } else if (\n            this.BuildPipelineFormControl?.value === 'github-artifacts-release'\n        ) {\n            if (this.BuildPipelineFormGroup?.controls?.npmToken) {\n                this.BuildPipelineFormGroup.removeControl('npmToken');\n            }\n        }\n    }\n\n    protected loadProjectHostingDetails(): void {\n        this.HostingDetails.Loading = true;\n        this.appsFlowSvc.LoadProjectHostingDetails().subscribe(\n            (response: BaseModeledResponse<ProjectHostingDetails>) => {\n                this.HostingDetails = response.Model;\n                // console.log('response: ', response);\n                this.HostingDetails.Loading = false;\n\n                // console.log(' DevOpsAction.Path: ', this.DevOpsAction.Path);\n\n                const hostOption = this.HostingDetails?.HostingOptions?.find(\n                    (ho) => ho.Path === this.DevOpsAction.Path\n                );\n\n                this.BuildPipeline = hostOption?.Lookup;\n                // this.SelectedHostingOption = hostOption;\n\n                // console.log(\"Build Pipeline HERE= \", this.BuildPipeline);\n\n                this.setupControlsForForm();\n            },\n            (err) => {\n                console.log('ERR: ', err);\n                this.HostingDetails.Loading = false;\n            }\n        );\n        // console.log('HOSTING DETAILS: ', this.HostingDetails);\n    }\n}\n","<form\n    class=\"form-card\"\n    [formGroup]=\"BuildPipelineFormGroup\"\n    (ngSubmit)=\"SubmitBuildPipeline()\"\n>\n    <ng-container *ngIf=\"HostingDetails?.Loading || Loading\">\n        <skeleton-block class=\"s-block\" effect=\"wave\"></skeleton-block>\n\n        <skeleton-block class=\"s-block\" effect=\"wave\"></skeleton-block>\n\n        <ng-container *ngIf=\"SelectedHostingOption?.Inputs\">\n            <ng-container\n                *ngFor=\"let hostOption of HostingDetails?.HostingOptions\"\n            >\n                <skeleton-block class=\"s-block\" effect=\"wave\"></skeleton-block>\n            </ng-container>\n        </ng-container>\n\n        <skeleton-block *ngIf=\"\" class=\"s-block\" effect=\"wave\"></skeleton-block>\n    </ng-container>\n\n    <ng-container *ngIf=\"!HostingDetails?.Loading && !Loading\">\n        <!-- <div  *ngIf=\"!HostingDetails?.Loading\"> -->\n        <mat-form-field class=\"mat-full-width\">\n            <mat-select\n                formControlName=\"buildPipeline\"\n                placeholder=\"Build Pipeline\"\n                [disabled]=\"Disabled\"\n                (selectionChange)=\"BuildPipelineChanged()\"\n                required\n            >\n                <ng-container\n                    *ngFor=\"\n                        let hostOption of HostingDetails?.HostingOptions;\n                        let i = index\n                    \"\n                >\n                    <mat-option [value]=\"hostOption.Lookup\">\n                        {{ hostOption.Name }}\n                    </mat-option>\n                </ng-container>\n            </mat-select>\n\n            <mat-hint>\n                <ng-container\n                    *ngFor=\"let hostOption of HostingDetails?.HostingOptions\"\n                >\n                    <span *ngIf=\"BuildPipeline == hostOption?.Lookup\">\n                        {{ hostOption.Description }}\n                    </span>\n                </ng-container>\n            </mat-hint>\n        </mat-form-field>\n\n        <mat-form-field class=\"mat-full-width\">\n            <input\n                matInput\n                formControlName=\"devOpsActionName\"\n                placeholder=\"Name of DevOps Action\"\n                required=\"true\"\n            />\n        </mat-form-field>\n\n        <ng-container *ngFor=\"let input of SelectedHostingOption?.Inputs\">\n            <mat-form-field class=\"mat-full-width\">\n                <input\n                    matInput\n                    [formControlName]=\"input.Lookup\"\n                    [placeholder]=\"input.Placeholder\"\n                    [required]=\"input.Required\"\n                />\n\n                <mat-hint>{{ input.Hint }}</mat-hint>\n            </mat-form-field>\n        </ng-container>\n\n        <div *ngIf=\"BuildPipeline == 'npm-release'\">\n            <mat-form-field class=\"mat-full-width with-hint padding-bottom-4\">\n                <mat-icon matPrefix>security</mat-icon>\n\n                <input\n                    id=\"npm-token\"\n                    matInput\n                    type=\"text\"\n                    formControlName=\"npmToken\"\n                    placeholder=\"NPM token\"\n                    [required]=\"!Disabled\"\n                    style=\"-webkit-text-security: disc\"\n                />\n                <mat-hint>\n                    Securely publish to NPM, provide an NPM Personal Access\n                    Token (PAT) with publish access to the organization used for\n                    your NPM packages. Learn how to create and view access\n                    tokens\n                    <a\n                        href=\"https://docs.npmjs.com/creating-and-viewing-access-tokens\"\n                        target=\"_blank\"\n                        class=\"primary-link\"\n                    >\n                        here.\n                    </a>\n                </mat-hint>\n            </mat-form-field>\n        </div>\n        <!-- </div> -->\n\n        <!-- <div *ngIf=\"HostingDetails?.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\">Loading hosting details</h4>\n              </div>\n            </div>\n          </div> -->\n    </ng-container>\n    <!-- </mat-card-content> -->\n\n    <!-- <mat-card-actions fxLayoutAlign=\"center center\"> -->\n\n    <!-- <button \n          *ngIf=\"!Loading\"\n          mat-raised-button \n          type=\"submit\" \n          fxFlex=\"100%\" \n          color=\"primary\" \n          [disabled]=\"!BuildPipelineFormGroup.valid || !BuildPipelineFormGroup.dirty\">\n          <mat-icon>save</mat-icon>\n          Save Build Pipeline\n        </button> -->\n    <!-- <lcu-loader [loading]=\"Loading\"></lcu-loader>   -->\n\n    <!-- </mat-card-actions> -->\n    <!-- </mat-card> -->\n</form>\n"]}
@@ -209,11 +209,11 @@ export class DevopsSourceControlFormComponent {
209
209
  SaveSourceControl() {
210
210
  const saveEnvReq = {
211
211
  Environment: {
212
- // ...this.Environment,
212
+ ...this.Environment,
213
213
  Sources: this.Environment.Sources || {},
214
214
  },
215
- // EnvironmentLookup: this.EnvironmentLookup,
216
- // EnterpriseDataTokens: {},
215
+ EnvironmentLookup: this.EnvironmentLookup,
216
+ EnterpriseDataTokens: {},
217
217
  };
218
218
  let source = {
219
219
  ...this.EditingSourceControl,
@@ -394,4 +394,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
394
394
  type: ViewChild,
395
395
  args: ['branches']
396
396
  }] } });
397
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devops-source-control-form.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/controls/devops-source-control-form/devops-source-control-form.component.ts","../../../../../../projects/common/src/lib/controls/devops-source-control-form/devops-source-control-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { COMMA, ENTER } from '@angular/cdk/keycodes';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport {\n    AbstractControl,\n    FormBuilder,\n    FormControl,\n    FormGroup,\n    Validators,\n} from '@angular/forms';\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatChipInputEvent } from '@angular/material/chips';\nimport { MatSelectChange } from '@angular/material/select';\nimport { BaseModeledResponse, BaseResponse, Guid, Status } from '@lcu/common';\nimport {\n    EaCArtifact,\n    EaCDevOpsAction,\n    EaCEnvironmentAsCode,\n    EaCSourceControl,\n} from '@semanticjs/common';\nimport { ApplicationsFlowService } from '../../services/applications-flow.service';\nimport {\n    EaCService,\n    SaveEnvironmentAsCodeEventRequest,\n} from '../../services/eac.service';\nimport {\n    GitHubBranch,\n    GitHubOrganization,\n    GitHubRepository,\n    ProjectHostingDetails,\n} 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    @Input('editing-source-control-lookup')\n    public EditingSourceControlLookup: string;\n\n    @Input('environment')\n    public Environment: EaCEnvironmentAsCode;\n\n    @Input('environment-lookup')\n    public EnvironmentLookup: string;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Output('save-status-event')\n    public SaveStatusEvent: EventEmitter<Status>;\n\n    @ViewChild('branches')\n    public BranchesInput: ElementRef<HTMLInputElement>;\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    // 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    //  Properties\n\n    public get BranchesFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'branches'\n        );\n    }\n\n    public get BuildPathFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'buildPath'\n        );\n    }\n\n    public get DevOpsActionLookupFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get('devOpsActionLookup');\n    }\n\n    public get MainBranchFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'mainBranch'\n        );\n    }\n\n    public get OrganizationFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'organization'\n        );\n    }\n\n    public get RepositoryFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'repository'\n        );\n    }\n\n    public Artifact: EaCArtifact;\n\n    public ArtifactLookup: string;\n\n    public ArtifactLookups: Array<string>;\n\n    public BranchOptions: GitHubBranch[];\n\n    public BuildPathOptions: string[];\n\n    public CreatingRepository: boolean;\n\n    public DevOpsAction: EaCDevOpsAction;\n\n    public DevOpsActions: { [lookup: string]: EaCDevOpsAction };\n\n    public DevOpsActionLookup: string;\n\n    public DevOpsActionLookups: Array<string>;\n\n    public DevOpsSourceControlFormGroup: FormGroup;\n\n    public EditingSourceControl: EaCSourceControl;\n\n    public HostingDetails: ProjectHostingDetails;\n\n    public OrganizationOptions: GitHubOrganization[];\n\n    public RepositoryOptions: GitHubRepository[];\n\n    public SelectedBranches: string[];\n\n    public SkeletonEffect: string;\n\n    public readonly SeparatorKeysCodes = [ENTER, COMMA] as const;\n\n    //  Constructors\n    constructor(\n        protected appsFlowSvc: ApplicationsFlowService,\n        protected eacSvc: EaCService,\n        protected formBuilder: FormBuilder\n    ) {\n        this.SaveStatusEvent = new EventEmitter();\n\n        this.EditingSourceControl = {};\n\n        this.BuildPath = null;\n\n        this.HostingDetails = new ProjectHostingDetails();\n\n        this.SelectedBranches = [];\n\n        this.SourceControlRoot = '';\n\n        this.SkeletonEffect = 'wave';\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        console.log('source control lookup', this.EditingSourceControlLookup);\n\n        if (this.EditingSourceControlLookup === null) {\n            this.CreateNewSourceControl();\n        }\n        console.log('source control', this.EditingSourceControl);\n\n        if (this.EditingSourceControl != null) {\n            this.DevOpsSourceControlFormGroup = this.formBuilder.group({});\n\n            this.setupFormControls();\n        }\n\n        this.RefreshOrganizations();\n    }\n\n    public ngOnChanges() {\n        if (this.Environment) {\n            if (this.Environment?.Artifacts && this.ArtifactLookup) {\n                this.Artifact =\n                    this.Environment?.Artifacts[this.ArtifactLookup];\n            }\n\n            if (this.Environment?.DevOpsActions) {\n                this.DevOpsActions = this.Environment.DevOpsActions;\n\n                if (this.DevOpsActionLookup) {\n                    this.DevOpsAction =\n                        this.Environment.DevOpsActions[this.DevOpsActionLookup];\n                }\n            }\n\n            if (this.DevOpsAction?.ArtifactLookups) {\n                this.ArtifactLookups = this.DevOpsAction?.ArtifactLookups;\n\n                this.ArtifactLookup = this.DevOpsAction?.ArtifactLookups[0];\n            }\n        }\n        if (this.DevOpsActions) {\n            this.DevOpsActionLookups = Object.keys(this.DevOpsActions || {});\n        }\n\n        console.log('devopsAction lookups: ', this.DevOpsActionLookups);\n\n        if (this.Environment?.Sources && this.EditingSourceControlLookup) {\n            this.EditingSourceControl =\n                this.Environment?.Sources[this.EditingSourceControlLookup];\n        }\n\n        if (!!this.DevOpsActionLookupFormControl?.value) {\n            console.log(\n                'DevOpsActionLookupFormControl: ',\n                this.DevOpsActionLookupFormControl?.value\n            );\n            this.DevOpsActionLookup = this.DevOpsActionLookupFormControl?.value;\n        }\n\n        if (!!this.EditingSourceControl?.DevOpsActionTriggerLookups) {\n            this.DevOpsActionLookup =\n                this.EditingSourceControl?.DevOpsActionTriggerLookups[0];\n        } else {\n            this.DevOpsActionLookup = null;\n        }\n        console.log('devops action lookup = ', this.DevOpsActionLookup);\n        // console.log('form value', this.DevOpsActionLookupFormControl.value);\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        //do something??\n    }\n\n    public CreateNewSourceControl(): void {\n        this.SetEditingSourceControl(Guid.CreateRaw());\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 Log() {\n        console.log('form value', this.DevOpsActionLookupFormControl.value);\n    }\n\n    public DevOpsActionLookupChanged(event: MatSelectChange): void {\n        this.DevOpsActionLookup = event.value;\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    public SetEditingSourceControl(scLookup: string): void {\n        this.EditingSourceControlLookup = scLookup;\n    }\n\n    public SubmitSourceControl() {\n        console.log(\n            'source control submitted: ',\n            this.DevOpsSourceControlFormGroup.value\n        );\n        this.SaveSourceControl();\n    }\n\n    public SaveSourceControl(): void {\n        const saveEnvReq: SaveEnvironmentAsCodeEventRequest = {\n            Environment: {\n                // ...this.Environment,\n                Sources: this.Environment.Sources || {},\n            },\n            // EnvironmentLookup: this.EnvironmentLookup,\n            // EnterpriseDataTokens: {},\n        };\n\n        let source: EaCSourceControl = {\n            ...this.EditingSourceControl,\n            Branches: this.SelectedBranches,\n            MainBranch: this.MainBranchFormControl.value,\n        };\n\n        source = {\n            ...source,\n            Type: 'GitHub',\n            Name: `@${this.OrganizationFormControl.value}/${this.RepositoryFormControl.value}`,\n            DevOpsActionTriggerLookups: [this.DevOpsActionLookup],\n            Organization: this.OrganizationFormControl.value,\n            Repository: this.RepositoryFormControl.value,\n        };\n\n        const scLookup = `github://${source.Organization}/${source.Repository}`;\n\n        saveEnvReq.Environment.Sources[scLookup] = source;\n\n        console.log('save SC: ', saveEnvReq);\n\n        let resp = this.eacSvc.SaveEnvironmentAsCode(saveEnvReq);\n\n        resp.then((res) => {\n            this.SaveStatusEvent.emit(res);\n        });\n    }\n\n    //  Helpers\n\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(\n                this.DevOpsActionLookup\n            );\n        }, 0);\n    }\n\n    protected destroyFormControls(): void {\n        this.DevOpsSourceControlFormGroup.removeControl(\n            [this.SourceControlRoot, 'mainBranch'].join('')\n        );\n\n        this.DevOpsSourceControlFormGroup?.removeControl(\n            [this.SourceControlRoot, 'branches'].join('')\n        );\n\n        this.DevOpsSourceControlFormGroup?.removeControl(\n            [this.SourceControlRoot, 'buildPath'].join('')\n        );\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(\n                    this.MainBranchFormControl.value\n                ) < 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 =\n                            this.EditingSourceControl.Branches;\n                    } else if (this.BranchOptions?.length === 1) {\n                        this.BranchesFormControl.setValue(\n                            this.BranchOptions[0].Name\n                        );\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(\n                            this.BuildPathOptions[0]\n                        );\n                    }\n                });\n        }\n    }\n\n    protected listOrganizations(): void {\n        this.Loading = true;\n\n        this.appsFlowSvc\n            .ListOrganizations()\n            .subscribe(\n                (response: BaseModeledResponse<GitHubOrganization[]>) => {\n                    this.OrganizationOptions = response.Model;\n                    console.log(\n                        'Organization Options: ',\n                        this.OrganizationOptions\n                    );\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(\n                                this.EditingSourceControl?.Repository\n                            );\n                        }, 0);\n                    }\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.LoadProjectHostingDetails().subscribe(\n                (response: BaseModeledResponse<ProjectHostingDetails>) => {\n                    this.HostingDetails = response.Model;\n\n                    this.HostingDetails.Loading = false;\n\n                    this.configureDevOpsAction();\n                },\n                (err: any) => {\n                    this.HostingDetails.Loading = false;\n                }\n            );\n        }\n    }\n\n    protected setupFormControls(): void {\n        this.destroyFormControls();\n\n        console.log('Source Control: ', this.EditingSourceControl);\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(\n                this.EditingSourceControl.Repository ?? '',\n                Validators.required\n            )\n        );\n\n        if (this.UseBranches) {\n            this.DevOpsSourceControlFormGroup.addControl(\n                [this.SourceControlRoot, 'branches'].join(''),\n                new FormControl(\n                    this.EditingSourceControl?.Branches ?? '',\n                    Validators.required\n                )\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}\n","<form\n    class=\"form-card\"\n    [formGroup]=\"DevOpsSourceControlFormGroup\"\n    (ngSubmit)=\"SubmitSourceControl()\"\n    (click)=\"Log()\"\n>\n    <!-- <mat-card class=\"spread\" class=\"sc-card\"> -->\n    <!-- <mat-card-header>\n      <mat-card-title> Source Control </mat-card-title>\n\n      <div fxFlex></div>\n\n      <mat-icon matSuffix matTooltip=\"Configure source control, DevOps CI/CD, and artifacts.\">\n        info_outline\n      </mat-icon>\n    </mat-card-header> -->\n\n    <!-- <mat-card-content> -->\n\n    <ng-container *ngIf=\"Loading\">\n        <lcu-loader [loading]=\"Loading\"></lcu-loader>\n\n        <!-- <skeleton-block \n          class=\"s-block\"\n          [effect]=\"SkeletonEffect\" \n        ></skeleton-block>\n\n        <skeleton-block \n          class=\"s-block\"\n          [effect]=\"SkeletonEffect\" \n        ></skeleton-block>\n\n        <skeleton-block \n          class=\"s-block\"\n          [effect]=\"SkeletonEffect\"  \n        ></skeleton-block>\n\n        <skeleton-block \n          class=\"s-block\"\n          [effect]=\"SkeletonEffect\"  \n        ></skeleton-block> -->\n    </ng-container>\n\n    <ng-container *ngIf=\"!Loading\">\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                    required\n                >\n                    <ng-container\n                        *ngFor=\"let devOpsActionLookup of DevOpsActionLookups\"\n                    >\n                        <mat-option\n                            [value]=\"devOpsActionLookup\"\n                            *ngIf=\"\n                                DevOpsActions[devOpsActionLookup];\n                                let devOpsAction\n                            \"\n                            [matTooltip]=\"devOpsAction.Name\"\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 margin-bottom\"\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\n                    matSuffix\n                    (click)=\"RefreshOrganizations()\"\n                    matTooltip=\"Refresh Organization\"\n                    color=\"accent\"\n                >\n                    refresh\n                </mat-icon>\n\n                <a\n                    matSuffix\n                    href=\"/.oauth/GitHubOAuth?oauth-force-edit=true\"\n                    target=\"_blank\"\n                    color=\"accent\"\n                >\n                    <mat-icon\n                        color=\"accent\"\n                        matTooltip=\"Re-authorize Organizations\"\n                    >\n                        launch\n                    </mat-icon>\n                </a>\n\n                <mat-hint>\n                    If you don't have an organization or would like to create a\n                    new one,\n                    <a\n                        href=\"https://github.com/account/organizations/new\"\n                        class=\"primary-link\"\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 ||\n                        Loading ||\n                        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=\"\n                        !CreatingRepository && OrganizationFormControl?.valid\n                    \"\n                >\n                    add_circle\n                </mat-icon>\n\n                <button\n                    mat-button\n                    type=\"button\"\n                    (click)=\"SaveRepository()\"\n                    *ngIf=\"CreatingRepository && RepositoryFormControl?.valid\"\n                >\n                    <mat-icon matSuffix color=\"primary\"> save </mat-icon>\n                </button>\n\n                <button\n                    mat-button\n                    type=\"button\"\n                    (click)=\"CancelCreateRepository()\"\n                    *ngIf=\"CreatingRepository\"\n                >\n                    <mat-icon matSuffix> cancel </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\n                    matSuffix\n                    (click)=\"RefreshOrganizations()\"\n                    color=\"accent\"\n                >\n                    refresh\n                </mat-icon>\n\n                <a\n                    matSuffix\n                    mat-icon-button\n                    href=\"/.oauth/GitHubOAuth?oauth-force-edit=true\"\n                    target=\"_blank\"\n                    color=\"accent\"\n                >\n                    <mat-icon\n                        matTooltip=\"Re-authorize Organizations\"\n                        color=\"accent\"\n                    >\n                        launch\n                    </mat-icon>\n                </a>\n\n                <mat-hint>\n                    If you don't have an organization or would like to create a\n                    new one,\n                    <a\n                        href=\"https://github.com/account/organizations/new\"\n                        target=\"_blank\"\n                        class=\"primary-link\"\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\n                        class=\"mat-title\"\n                        *ngIf=\"!OrganizationFormControl?.valid\"\n                    >\n                        Loading organizations\n                    </h4>\n\n                    <h4\n                        class=\"mat-title\"\n                        *ngIf=\"\n                            OrganizationFormControl?.valid &&\n                            !RepositoryFormControl?.valid\n                        \"\n                    >\n                        Loading repositories\n                    </h4>\n\n                    <h4\n                        class=\"mat-title\"\n                        *ngIf=\"\n                            RepositoryFormControl?.valid &&\n                            !BranchesFormControl?.valid\n                        \"\n                    >\n                        Loading branches\n                    </h4>\n\n                    <h4\n                        class=\"mat-title\"\n                        *ngIf=\"\n                            (RepositoryFormControl?.valid ||\n                                BranchesFormControl?.valid) &&\n                            !BuildPathFormControl?.valid\n                        \"\n                    >\n                        Loading build paths\n                    </h4>\n                </div>\n            </div>\n        </div>\n    </ng-container>\n    <!-- </div> -->\n\n    <!-- </mat-card-content> -->\n    <!-- <mat-card-actions fxLayoutAlign=\"center center\"> -->\n\n    <!-- <button \n        mat-raised-button \n        *ngIf=\"!Loading\"\n        type=\"submit\" \n        fxFlex=\"100%\" \n        color=\"primary\" \n        [disabled]=\"!DevOpsSourceControlFormGroup.valid || !DevOpsSourceControlFormGroup.dirty\">\n        <mat-icon>save</mat-icon>\n        Save Source Control\n      </button>\n      <lcu-loader [loading]=\"Loading\"></lcu-loader> -->\n\n    <!-- </mat-card-actions> -->\n    <!-- </mat-card> -->\n</form>\n"]}
397
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devops-source-control-form.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/controls/devops-source-control-form/devops-source-control-form.component.ts","../../../../../../projects/common/src/lib/controls/devops-source-control-form/devops-source-control-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { COMMA, ENTER } from '@angular/cdk/keycodes';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport {\n    AbstractControl,\n    FormBuilder,\n    FormControl,\n    FormGroup,\n    Validators,\n} from '@angular/forms';\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatChipInputEvent } from '@angular/material/chips';\nimport { MatSelectChange } from '@angular/material/select';\nimport { BaseModeledResponse, BaseResponse, Guid, Status } from '@lcu/common';\nimport {\n    EaCArtifact,\n    EaCDevOpsAction,\n    EaCEnvironmentAsCode,\n    EaCSourceControl,\n} from '@semanticjs/common';\nimport { ApplicationsFlowService } from '../../services/applications-flow.service';\nimport {\n    EaCService,\n    SaveEnvironmentAsCodeEventRequest,\n} from '../../services/eac.service';\nimport {\n    GitHubBranch,\n    GitHubOrganization,\n    GitHubRepository,\n    ProjectHostingDetails,\n} 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    @Input('editing-source-control-lookup')\n    public EditingSourceControlLookup: string;\n\n    @Input('environment')\n    public Environment: EaCEnvironmentAsCode;\n\n    @Input('environment-lookup')\n    public EnvironmentLookup: string;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Output('save-status-event')\n    public SaveStatusEvent: EventEmitter<Status>;\n\n    @ViewChild('branches')\n    public BranchesInput: ElementRef<HTMLInputElement>;\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    // 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    //  Properties\n\n    public get BranchesFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'branches'\n        );\n    }\n\n    public get BuildPathFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'buildPath'\n        );\n    }\n\n    public get DevOpsActionLookupFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get('devOpsActionLookup');\n    }\n\n    public get MainBranchFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'mainBranch'\n        );\n    }\n\n    public get OrganizationFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'organization'\n        );\n    }\n\n    public get RepositoryFormControl(): AbstractControl {\n        return this.DevOpsSourceControlFormGroup?.get(\n            this.SourceControlRoot + 'repository'\n        );\n    }\n\n    public Artifact: EaCArtifact;\n\n    public ArtifactLookup: string;\n\n    public ArtifactLookups: Array<string>;\n\n    public BranchOptions: GitHubBranch[];\n\n    public BuildPathOptions: string[];\n\n    public CreatingRepository: boolean;\n\n    public DevOpsAction: EaCDevOpsAction;\n\n    public DevOpsActions: { [lookup: string]: EaCDevOpsAction };\n\n    public DevOpsActionLookup: string;\n\n    public DevOpsActionLookups: Array<string>;\n\n    public DevOpsSourceControlFormGroup: FormGroup;\n\n    public EditingSourceControl: EaCSourceControl;\n\n    public HostingDetails: ProjectHostingDetails;\n\n    public OrganizationOptions: GitHubOrganization[];\n\n    public RepositoryOptions: GitHubRepository[];\n\n    public SelectedBranches: string[];\n\n    public SkeletonEffect: string;\n\n    public readonly SeparatorKeysCodes = [ENTER, COMMA] as const;\n\n    //  Constructors\n    constructor(\n        protected appsFlowSvc: ApplicationsFlowService,\n        protected eacSvc: EaCService,\n        protected formBuilder: FormBuilder\n    ) {\n        this.SaveStatusEvent = new EventEmitter();\n\n        this.EditingSourceControl = {};\n\n        this.BuildPath = null;\n\n        this.HostingDetails = new ProjectHostingDetails();\n\n        this.SelectedBranches = [];\n\n        this.SourceControlRoot = '';\n\n        this.SkeletonEffect = 'wave';\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        console.log('source control lookup', this.EditingSourceControlLookup);\n\n        if (this.EditingSourceControlLookup === null) {\n            this.CreateNewSourceControl();\n        }\n        console.log('source control', this.EditingSourceControl);\n\n        if (this.EditingSourceControl != null) {\n            this.DevOpsSourceControlFormGroup = this.formBuilder.group({});\n\n            this.setupFormControls();\n        }\n\n        this.RefreshOrganizations();\n    }\n\n    public ngOnChanges() {\n        if (this.Environment) {\n            if (this.Environment?.Artifacts && this.ArtifactLookup) {\n                this.Artifact =\n                    this.Environment?.Artifacts[this.ArtifactLookup];\n            }\n\n            if (this.Environment?.DevOpsActions) {\n                this.DevOpsActions = this.Environment.DevOpsActions;\n\n                if (this.DevOpsActionLookup) {\n                    this.DevOpsAction =\n                        this.Environment.DevOpsActions[this.DevOpsActionLookup];\n                }\n            }\n\n            if (this.DevOpsAction?.ArtifactLookups) {\n                this.ArtifactLookups = this.DevOpsAction?.ArtifactLookups;\n\n                this.ArtifactLookup = this.DevOpsAction?.ArtifactLookups[0];\n            }\n        }\n        if (this.DevOpsActions) {\n            this.DevOpsActionLookups = Object.keys(this.DevOpsActions || {});\n        }\n\n        console.log('devopsAction lookups: ', this.DevOpsActionLookups);\n\n        if (this.Environment?.Sources && this.EditingSourceControlLookup) {\n            this.EditingSourceControl =\n                this.Environment?.Sources[this.EditingSourceControlLookup];\n        }\n\n        if (!!this.DevOpsActionLookupFormControl?.value) {\n            console.log(\n                'DevOpsActionLookupFormControl: ',\n                this.DevOpsActionLookupFormControl?.value\n            );\n            this.DevOpsActionLookup = this.DevOpsActionLookupFormControl?.value;\n        }\n\n        if (!!this.EditingSourceControl?.DevOpsActionTriggerLookups) {\n            this.DevOpsActionLookup =\n                this.EditingSourceControl?.DevOpsActionTriggerLookups[0];\n        } else {\n            this.DevOpsActionLookup = null;\n        }\n        console.log('devops action lookup = ', this.DevOpsActionLookup);\n        // console.log('form value', this.DevOpsActionLookupFormControl.value);\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        //do something??\n    }\n\n    public CreateNewSourceControl(): void {\n        this.SetEditingSourceControl(Guid.CreateRaw());\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 Log() {\n        console.log('form value', this.DevOpsActionLookupFormControl.value);\n    }\n\n    public DevOpsActionLookupChanged(event: MatSelectChange): void {\n        this.DevOpsActionLookup = event.value;\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    public SetEditingSourceControl(scLookup: string): void {\n        this.EditingSourceControlLookup = scLookup;\n    }\n\n    public SubmitSourceControl() {\n        console.log(\n            'source control submitted: ',\n            this.DevOpsSourceControlFormGroup.value\n        );\n        this.SaveSourceControl();\n    }\n\n    public SaveSourceControl(): void {\n        const saveEnvReq: SaveEnvironmentAsCodeEventRequest = {\n            Environment: {\n                ...this.Environment,\n                Sources: this.Environment.Sources || {},\n            },\n            EnvironmentLookup: this.EnvironmentLookup,\n            EnterpriseDataTokens: {},\n        };\n\n        let source: EaCSourceControl = {\n            ...this.EditingSourceControl,\n            Branches: this.SelectedBranches,\n            MainBranch: this.MainBranchFormControl.value,\n        };\n\n        source = {\n            ...source,\n            Type: 'GitHub',\n            Name: `@${this.OrganizationFormControl.value}/${this.RepositoryFormControl.value}`,\n            DevOpsActionTriggerLookups: [this.DevOpsActionLookup],\n            Organization: this.OrganizationFormControl.value,\n            Repository: this.RepositoryFormControl.value,\n        };\n\n        const scLookup = `github://${source.Organization}/${source.Repository}`;\n\n        saveEnvReq.Environment.Sources[scLookup] = source;\n\n        console.log('save SC: ', saveEnvReq);\n\n        let resp = this.eacSvc.SaveEnvironmentAsCode(saveEnvReq);\n\n        resp.then((res) => {\n            this.SaveStatusEvent.emit(res);\n        });\n    }\n\n    //  Helpers\n\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(\n                this.DevOpsActionLookup\n            );\n        }, 0);\n    }\n\n    protected destroyFormControls(): void {\n        this.DevOpsSourceControlFormGroup.removeControl(\n            [this.SourceControlRoot, 'mainBranch'].join('')\n        );\n\n        this.DevOpsSourceControlFormGroup?.removeControl(\n            [this.SourceControlRoot, 'branches'].join('')\n        );\n\n        this.DevOpsSourceControlFormGroup?.removeControl(\n            [this.SourceControlRoot, 'buildPath'].join('')\n        );\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(\n                    this.MainBranchFormControl.value\n                ) < 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 =\n                            this.EditingSourceControl.Branches;\n                    } else if (this.BranchOptions?.length === 1) {\n                        this.BranchesFormControl.setValue(\n                            this.BranchOptions[0].Name\n                        );\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(\n                            this.BuildPathOptions[0]\n                        );\n                    }\n                });\n        }\n    }\n\n    protected listOrganizations(): void {\n        this.Loading = true;\n\n        this.appsFlowSvc\n            .ListOrganizations()\n            .subscribe(\n                (response: BaseModeledResponse<GitHubOrganization[]>) => {\n                    this.OrganizationOptions = response.Model;\n                    console.log(\n                        'Organization Options: ',\n                        this.OrganizationOptions\n                    );\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(\n                                this.EditingSourceControl?.Repository\n                            );\n                        }, 0);\n                    }\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.LoadProjectHostingDetails().subscribe(\n                (response: BaseModeledResponse<ProjectHostingDetails>) => {\n                    this.HostingDetails = response.Model;\n\n                    this.HostingDetails.Loading = false;\n\n                    this.configureDevOpsAction();\n                },\n                (err: any) => {\n                    this.HostingDetails.Loading = false;\n                }\n            );\n        }\n    }\n\n    protected setupFormControls(): void {\n        this.destroyFormControls();\n\n        console.log('Source Control: ', this.EditingSourceControl);\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(\n                this.EditingSourceControl.Repository ?? '',\n                Validators.required\n            )\n        );\n\n        if (this.UseBranches) {\n            this.DevOpsSourceControlFormGroup.addControl(\n                [this.SourceControlRoot, 'branches'].join(''),\n                new FormControl(\n                    this.EditingSourceControl?.Branches ?? '',\n                    Validators.required\n                )\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}\n","<form\n    class=\"form-card\"\n    [formGroup]=\"DevOpsSourceControlFormGroup\"\n    (ngSubmit)=\"SubmitSourceControl()\"\n    (click)=\"Log()\"\n>\n    <!-- <mat-card class=\"spread\" class=\"sc-card\"> -->\n    <!-- <mat-card-header>\n      <mat-card-title> Source Control </mat-card-title>\n\n      <div fxFlex></div>\n\n      <mat-icon matSuffix matTooltip=\"Configure source control, DevOps CI/CD, and artifacts.\">\n        info_outline\n      </mat-icon>\n    </mat-card-header> -->\n\n    <!-- <mat-card-content> -->\n\n    <ng-container *ngIf=\"Loading\">\n        <lcu-loader [loading]=\"Loading\"></lcu-loader>\n\n        <!-- <skeleton-block \n          class=\"s-block\"\n          [effect]=\"SkeletonEffect\" \n        ></skeleton-block>\n\n        <skeleton-block \n          class=\"s-block\"\n          [effect]=\"SkeletonEffect\" \n        ></skeleton-block>\n\n        <skeleton-block \n          class=\"s-block\"\n          [effect]=\"SkeletonEffect\"  \n        ></skeleton-block>\n\n        <skeleton-block \n          class=\"s-block\"\n          [effect]=\"SkeletonEffect\"  \n        ></skeleton-block> -->\n    </ng-container>\n\n    <ng-container *ngIf=\"!Loading\">\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                    required\n                >\n                    <ng-container\n                        *ngFor=\"let devOpsActionLookup of DevOpsActionLookups\"\n                    >\n                        <mat-option\n                            [value]=\"devOpsActionLookup\"\n                            *ngIf=\"\n                                DevOpsActions[devOpsActionLookup];\n                                let devOpsAction\n                            \"\n                            [matTooltip]=\"devOpsAction.Name\"\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 margin-bottom\"\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\n                    matSuffix\n                    (click)=\"RefreshOrganizations()\"\n                    matTooltip=\"Refresh Organization\"\n                    color=\"accent\"\n                >\n                    refresh\n                </mat-icon>\n\n                <a\n                    matSuffix\n                    href=\"/.oauth/GitHubOAuth?oauth-force-edit=true\"\n                    target=\"_blank\"\n                    color=\"accent\"\n                >\n                    <mat-icon\n                        color=\"accent\"\n                        matTooltip=\"Re-authorize Organizations\"\n                    >\n                        launch\n                    </mat-icon>\n                </a>\n\n                <mat-hint>\n                    If you don't have an organization or would like to create a\n                    new one,\n                    <a\n                        href=\"https://github.com/account/organizations/new\"\n                        class=\"primary-link\"\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 ||\n                        Loading ||\n                        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=\"\n                        !CreatingRepository && OrganizationFormControl?.valid\n                    \"\n                >\n                    add_circle\n                </mat-icon>\n\n                <button\n                    mat-button\n                    type=\"button\"\n                    (click)=\"SaveRepository()\"\n                    *ngIf=\"CreatingRepository && RepositoryFormControl?.valid\"\n                >\n                    <mat-icon matSuffix color=\"primary\"> save </mat-icon>\n                </button>\n\n                <button\n                    mat-button\n                    type=\"button\"\n                    (click)=\"CancelCreateRepository()\"\n                    *ngIf=\"CreatingRepository\"\n                >\n                    <mat-icon matSuffix> cancel </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\n                    matSuffix\n                    (click)=\"RefreshOrganizations()\"\n                    color=\"accent\"\n                >\n                    refresh\n                </mat-icon>\n\n                <a\n                    matSuffix\n                    mat-icon-button\n                    href=\"/.oauth/GitHubOAuth?oauth-force-edit=true\"\n                    target=\"_blank\"\n                    color=\"accent\"\n                >\n                    <mat-icon\n                        matTooltip=\"Re-authorize Organizations\"\n                        color=\"accent\"\n                    >\n                        launch\n                    </mat-icon>\n                </a>\n\n                <mat-hint>\n                    If you don't have an organization or would like to create a\n                    new one,\n                    <a\n                        href=\"https://github.com/account/organizations/new\"\n                        target=\"_blank\"\n                        class=\"primary-link\"\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\n                        class=\"mat-title\"\n                        *ngIf=\"!OrganizationFormControl?.valid\"\n                    >\n                        Loading organizations\n                    </h4>\n\n                    <h4\n                        class=\"mat-title\"\n                        *ngIf=\"\n                            OrganizationFormControl?.valid &&\n                            !RepositoryFormControl?.valid\n                        \"\n                    >\n                        Loading repositories\n                    </h4>\n\n                    <h4\n                        class=\"mat-title\"\n                        *ngIf=\"\n                            RepositoryFormControl?.valid &&\n                            !BranchesFormControl?.valid\n                        \"\n                    >\n                        Loading branches\n                    </h4>\n\n                    <h4\n                        class=\"mat-title\"\n                        *ngIf=\"\n                            (RepositoryFormControl?.valid ||\n                                BranchesFormControl?.valid) &&\n                            !BuildPathFormControl?.valid\n                        \"\n                    >\n                        Loading build paths\n                    </h4>\n                </div>\n            </div>\n        </div>\n    </ng-container>\n    <!-- </div> -->\n\n    <!-- </mat-card-content> -->\n    <!-- <mat-card-actions fxLayoutAlign=\"center center\"> -->\n\n    <!-- <button \n        mat-raised-button \n        *ngIf=\"!Loading\"\n        type=\"submit\" \n        fxFlex=\"100%\" \n        color=\"primary\" \n        [disabled]=\"!DevOpsSourceControlFormGroup.valid || !DevOpsSourceControlFormGroup.dirty\">\n        <mat-icon>save</mat-icon>\n        Save Source Control\n      </button>\n      <lcu-loader [loading]=\"Loading\"></lcu-loader> -->\n\n    <!-- </mat-card-actions> -->\n    <!-- </mat-card> -->\n</form>\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, } from '@angular/core';
2
2
  import { Validators, } from '@angular/forms';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/forms";
@@ -70,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
70
70
  type: Output,
71
71
  args: ['save-form-event']
72
72
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source-control-form.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/controls/source-control-form/source-control-form.component.ts","../../../../../../projects/common/src/lib/controls/source-control-form/source-control-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAIH,UAAU,GACb,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;AAaxB,MAAM,OAAO,0BAA0B;IAgCnC,YAAsB,QAAqB;QAArB,aAAQ,GAAR,QAAQ,CAAa;QACvC,IAAI,CAAC,aAAa,GAAG,IAAI,YAAY,EAAE,CAAC;IAC5C,CAAC;IAxBD,IAAW,mBAAmB;QAC1B,OAAO,IAAI,CAAC,sBAAsB,EAAE,QAAQ,CAAC,QAAQ,CAAC;IAC1D,CAAC;IAED,IAAW,8BAA8B;QACrC,OAAO,IAAI,CAAC,sBAAsB,EAAE,QAAQ,CAAC,mBAAmB,CAAC;IACrE,CAAC;IAED,IAAW,oBAAoB;QAC3B,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC;IAClD,CAAC;IAED,IAAW,cAAc;QACrB,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,IAAI,EAAE,CAAC;IAC1C,CAAC;IAYM,QAAQ;QACX,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAClC,CAAC;IAEM,cAAc,CAAC,KAAU;QAC5B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC;IACnD,CAAC;IAEM,0BAA0B,CAAC,KAAsB;QACpD,yCAAyC;QACzC,OAAO,CAAC,GAAG,CAAC,8BAA8B,EAAE,KAAK,CAAC,CAAC;IACvD,CAAC;IAEM,mBAAmB;QACtB,OAAO,CAAC,GAAG,CACP,6BAA6B,EAC7B,IAAI,CAAC,sBAAsB,CAAC,KAAK,CACpC,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;IAC/D,CAAC;IAED,QAAQ;IAEE,sBAAsB;QAC5B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,kBAAkB,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC;QAEpE,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAEtD,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAES,cAAc;QACpB,IAAI,CAAC,sBAAsB,CAAC,UAAU,CAClC,UAAU,EACV,IAAI,CAAC,QAAQ,CAAC,OAAO,CACjB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,mBAAmB;YACtD,KAAK,EACT,CAAC,UAAU,CAAC,QAAQ,CAAC,CACxB,CACJ,CAAC;QAEF,IAAI,CAAC,sBAAsB,CAAC,UAAU,CAClC,qBAAqB,EACrB,IAAI,CAAC,QAAQ,CAAC,OAAO,CACjB,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,mBAAmB,IAAI,EAAE,EAC9D,EAAE,CACL,CACJ,CAAC;IACN,CAAC;;uHApFQ,0BAA0B;2GAA1B,0BAA0B,0OCnBvC,kiHAmGA;2FDhFa,0BAA0B;kBALtC,SAAS;+BACI,yBAAyB;kGAM5B,kBAAkB;sBADxB,KAAK;uBAAC,qBAAqB;gBAIrB,WAAW;sBADjB,KAAK;uBAAC,aAAa;gBAIb,aAAa;sBADnB,MAAM;uBAAC,iBAAiB","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n    AbstractControl,\n    FormBuilder,\n    FormGroup,\n    Validators,\n} from '@angular/forms';\nimport { MatSelectChange } from '@angular/material/select';\nimport {\n    EaCApplicationAsCode,\n    EaCEnvironmentAsCode,\n    EaCSourceControl,\n} from '@semanticjs/common';\n\n@Component({\n    selector: 'lcu-source-control-form',\n    templateUrl: './source-control-form.component.html',\n    styleUrls: ['./source-control-form.component.scss'],\n})\nexport class SourceControlFormComponent implements OnInit {\n    @Input('editing-application')\n    public EditingApplication: EaCApplicationAsCode;\n\n    @Input('environment')\n    public Environment: EaCEnvironmentAsCode;\n\n    @Output('save-form-event')\n    public SaveFormEvent: EventEmitter<{}>;\n\n    public get HasBuildFormControl(): AbstractControl {\n        return this.SourceControlFormGroup?.controls.hasBuild;\n    }\n\n    public get SourceControlLookupFormControl(): AbstractControl {\n        return this.SourceControlFormGroup?.controls.sourceControlLookup;\n    }\n\n    public get SourceControlLookups(): Array<string> {\n        return Object.keys(this.SourceControls || {});\n    }\n\n    public get SourceControls(): { [lookup: string]: EaCSourceControl } {\n        return this.Environment.Sources || {};\n    }\n\n    public HasBuild: boolean;\n\n    public SourceControlFormGroup: FormGroup;\n\n    public ProcessorType: string;\n\n    constructor(protected formBldr: FormBuilder) {\n        this.SaveFormEvent = new EventEmitter();\n    }\n\n    public ngOnInit(): void {\n        this.setupSourceControlForm();\n    }\n\n    public HandleHasBuild(event: any) {\n        this.HasBuild = this.HasBuildFormControl.value;\n    }\n\n    public SourceControlLookupChanged(event: MatSelectChange): void {\n        //  TODO:  Anything to do here on change?\n        console.log('sourceControlLookupChanged: ', event);\n    }\n\n    public SubmitSourceControl() {\n        console.log(\n            'submitting source control: ',\n            this.SourceControlFormGroup.value\n        );\n        this.SaveFormEvent.emit(this.SourceControlFormGroup.value);\n    }\n\n    //HELPER\n\n    protected setupSourceControlForm(): void {\n        this.ProcessorType = this.EditingApplication?.Processor?.Type || '';\n\n        this.SourceControlFormGroup = this.formBldr.group({});\n\n        this.setupBuildForm();\n    }\n\n    protected setupBuildForm(): void {\n        this.SourceControlFormGroup.addControl(\n            'hasBuild',\n            this.formBldr.control(\n                !!this.EditingApplication.LowCodeUnit?.SourceControlLookup ||\n                    false,\n                [Validators.required]\n            )\n        );\n\n        this.SourceControlFormGroup.addControl(\n            'sourceControlLookup',\n            this.formBldr.control(\n                this.EditingApplication.LowCodeUnit?.SourceControlLookup || '',\n                []\n            )\n        );\n    }\n}\n","<form\n    class=\"source-control-form\"\n    [formGroup]=\"SourceControlFormGroup\"\n    (ngSubmit)=\"SubmitSourceControl()\"\n>\n    <mat-card class=\"spread flow-card\" *ngIf=\"ProcessorType != 'Redirect'\">\n        <mat-card-header>\n            <mat-card-title *ngIf=\"!HasBuild\"> Build & Source </mat-card-title>\n\n            <mat-card-title *ngIf=\"HasBuild\"> Source Control </mat-card-title>\n\n            <div fxFlex></div>\n\n            <mat-slide-toggle\n                formControlName=\"hasBuild\"\n                matTooltip=\"Has Build?\"\n                (change)=\"HandleHasBuild($event)\"\n            >\n            </mat-slide-toggle>\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            <mat-form-field\n                class=\"mat-full-width\"\n                *ngIf=\"HasBuild && SourceControlLookups?.length > 0\"\n            >\n                <mat-select\n                    formControlName=\"sourceControlLookup\"\n                    placeholder=\"Source Control\"\n                    (selectionChange)=\"SourceControlLookupChanged($event)\"\n                    [disabled]=\"\n                        SourceControlFormControls?.Loading ||\n                        HostingDetails?.Loading\n                    \"\n                >\n                    <ng-container\n                        *ngFor=\"let srcCtrlLookup of SourceControlLookups\"\n                    >\n                        <mat-option\n                            [value]=\"srcCtrlLookup\"\n                            *ngIf=\"SourceControls[srcCtrlLookup]; let srcCtrl\"\n                        >\n                            {{ srcCtrl.Name }}\n                        </mat-option>\n                    </ng-container>\n                </mat-select>\n\n                <div *ngIf=\"HasBuild\">\n                    <h3>\n                        @{{\n                            SourceControlFormControls?.OrganizationFormControl\n                                ?.value || SourceControl?.Organization\n                        }}/{{\n                            SourceControlFormControls?.RepositoryFormControl\n                                ?.value || SourceControl?.Repository\n                        }}\n                    </h3>\n\n                    <p>\n                        Organization and Repository pulled from build settings\n                    </p>\n\n                    <mat-hint>\n                        CurrentBuild:\n                        {{ EditingApplication?.LowCodeUnit?.CurrentBuild }}\n                    </mat-hint>\n                </div>\n            </mat-form-field>\n\n            <div *ngIf=\"SourceControlLookups?.length < 0\">\n                <h3>\n                    Create source control locations under the DevOps tab above.\n                </h3>\n            </div>\n        </mat-card-content>\n        <mat-card-actions fxLayoutAlign=\"center center\">\n            <button\n                mat-raised-button\n                type=\"submit\"\n                fxFlex=\"100%\"\n                color=\"primary\"\n                [disabled]=\"\n                    !SourceControlFormGroup.valid ||\n                    !SourceControlFormGroup.dirty\n                \"\n            >\n                <mat-icon>save</mat-icon>\n                Save\n            </button>\n        </mat-card-actions>\n    </mat-card>\n</form>\n"]}
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source-control-form.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/controls/source-control-form/source-control-form.component.ts","../../../../../../projects/common/src/lib/controls/source-control-form/source-control-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,GAET,MAAM,eAAe,CAAC;AACvB,OAAO,EAIH,UAAU,GACb,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;AAexB,MAAM,OAAO,0BAA0B;IAgCnC,YAAsB,QAAqB;QAArB,aAAQ,GAAR,QAAQ,CAAa;QACvC,IAAI,CAAC,aAAa,GAAG,IAAI,YAAY,EAAE,CAAC;IAC5C,CAAC;IAxBD,IAAW,mBAAmB;QAC1B,OAAO,IAAI,CAAC,sBAAsB,EAAE,QAAQ,CAAC,QAAQ,CAAC;IAC1D,CAAC;IAED,IAAW,8BAA8B;QACrC,OAAO,IAAI,CAAC,sBAAsB,EAAE,QAAQ,CAAC,mBAAmB,CAAC;IACrE,CAAC;IAED,IAAW,oBAAoB;QAC3B,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC;IAClD,CAAC;IAED,IAAW,cAAc;QACrB,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,IAAI,EAAE,CAAC;IAC1C,CAAC;IAYM,QAAQ;QACX,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAClC,CAAC;IAEM,cAAc,CAAC,KAAU;QAC5B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC;IACnD,CAAC;IAEM,0BAA0B,CAAC,KAAsB;QACpD,yCAAyC;QACzC,OAAO,CAAC,GAAG,CAAC,8BAA8B,EAAE,KAAK,CAAC,CAAC;IACvD,CAAC;IAEM,mBAAmB;QACtB,OAAO,CAAC,GAAG,CACP,6BAA6B,EAC7B,IAAI,CAAC,sBAAsB,CAAC,KAAK,CACpC,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;IAC/D,CAAC;IAED,QAAQ;IAEE,sBAAsB;QAC5B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,kBAAkB,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC;QAEpE,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAEtD,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAES,cAAc;QACpB,IAAI,CAAC,sBAAsB,CAAC,UAAU,CAClC,UAAU,EACV,IAAI,CAAC,QAAQ,CAAC,OAAO,CACjB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,mBAAmB;YACtD,KAAK,EACT,CAAC,UAAU,CAAC,QAAQ,CAAC,CACxB,CACJ,CAAC;QAEF,IAAI,CAAC,sBAAsB,CAAC,UAAU,CAClC,qBAAqB,EACrB,IAAI,CAAC,QAAQ,CAAC,OAAO,CACjB,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,mBAAmB,IAAI,EAAE,EAC9D,EAAE,CACL,CACJ,CAAC;IACN,CAAC;;uHApFQ,0BAA0B;2GAA1B,0BAA0B,0OC5BvC,kiHAmGA;2FDvEa,0BAA0B;kBALtC,SAAS;+BACI,yBAAyB;kGAM5B,kBAAkB;sBADxB,KAAK;uBAAC,qBAAqB;gBAIrB,WAAW;sBADjB,KAAK;uBAAC,aAAa;gBAIb,aAAa;sBADnB,MAAM;uBAAC,iBAAiB","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    Input,\n    OnInit,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport {\n    AbstractControl,\n    FormBuilder,\n    FormGroup,\n    Validators,\n} from '@angular/forms';\nimport { MatSelectChange } from '@angular/material/select';\nimport {\n    EaCApplicationAsCode,\n    EaCEnvironmentAsCode,\n    EaCProjectAsCode,\n    EaCSourceControl,\n} from '@semanticjs/common';\nimport { SourceControlFormControlsComponent } from '../../elements/projects/controls/forms/source-control/source-control.component';\n\n@Component({\n    selector: 'lcu-source-control-form',\n    templateUrl: './source-control-form.component.html',\n    styleUrls: ['./source-control-form.component.scss'],\n})\nexport class SourceControlFormComponent implements OnInit {\n    @Input('editing-application')\n    public EditingApplication: EaCApplicationAsCode;\n\n    @Input('environment')\n    public Environment: EaCEnvironmentAsCode;\n\n    @Output('save-form-event')\n    public SaveFormEvent: EventEmitter<{}>;\n\n    public get HasBuildFormControl(): AbstractControl {\n        return this.SourceControlFormGroup?.controls.hasBuild;\n    }\n\n    public get SourceControlLookupFormControl(): AbstractControl {\n        return this.SourceControlFormGroup?.controls.sourceControlLookup;\n    }\n\n    public get SourceControlLookups(): Array<string> {\n        return Object.keys(this.SourceControls || {});\n    }\n\n    public get SourceControls(): { [lookup: string]: EaCSourceControl } {\n        return this.Environment.Sources || {};\n    }\n\n    public HasBuild: boolean;\n\n    public SourceControlFormGroup: FormGroup;\n\n    public ProcessorType: string;\n\n    constructor(protected formBldr: FormBuilder) {\n        this.SaveFormEvent = new EventEmitter();\n    }\n\n    public ngOnInit(): void {\n        this.setupSourceControlForm();\n    }\n\n    public HandleHasBuild(event: any) {\n        this.HasBuild = this.HasBuildFormControl.value;\n    }\n\n    public SourceControlLookupChanged(event: MatSelectChange): void {\n        //  TODO:  Anything to do here on change?\n        console.log('sourceControlLookupChanged: ', event);\n    }\n\n    public SubmitSourceControl() {\n        console.log(\n            'submitting source control: ',\n            this.SourceControlFormGroup.value\n        );\n        this.SaveFormEvent.emit(this.SourceControlFormGroup.value);\n    }\n\n    //HELPER\n\n    protected setupSourceControlForm(): void {\n        this.ProcessorType = this.EditingApplication?.Processor?.Type || '';\n\n        this.SourceControlFormGroup = this.formBldr.group({});\n\n        this.setupBuildForm();\n    }\n\n    protected setupBuildForm(): void {\n        this.SourceControlFormGroup.addControl(\n            'hasBuild',\n            this.formBldr.control(\n                !!this.EditingApplication.LowCodeUnit?.SourceControlLookup ||\n                    false,\n                [Validators.required]\n            )\n        );\n\n        this.SourceControlFormGroup.addControl(\n            'sourceControlLookup',\n            this.formBldr.control(\n                this.EditingApplication.LowCodeUnit?.SourceControlLookup || '',\n                []\n            )\n        );\n    }\n}\n","<form\n    class=\"source-control-form\"\n    [formGroup]=\"SourceControlFormGroup\"\n    (ngSubmit)=\"SubmitSourceControl()\"\n>\n    <mat-card class=\"spread flow-card\" *ngIf=\"ProcessorType != 'Redirect'\">\n        <mat-card-header>\n            <mat-card-title *ngIf=\"!HasBuild\"> Build & Source </mat-card-title>\n\n            <mat-card-title *ngIf=\"HasBuild\"> Source Control </mat-card-title>\n\n            <div fxFlex></div>\n\n            <mat-slide-toggle\n                formControlName=\"hasBuild\"\n                matTooltip=\"Has Build?\"\n                (change)=\"HandleHasBuild($event)\"\n            >\n            </mat-slide-toggle>\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            <mat-form-field\n                class=\"mat-full-width\"\n                *ngIf=\"HasBuild && SourceControlLookups?.length > 0\"\n            >\n                <mat-select\n                    formControlName=\"sourceControlLookup\"\n                    placeholder=\"Source Control\"\n                    (selectionChange)=\"SourceControlLookupChanged($event)\"\n                    [disabled]=\"\n                        SourceControlFormControls?.Loading ||\n                        HostingDetails?.Loading\n                    \"\n                >\n                    <ng-container\n                        *ngFor=\"let srcCtrlLookup of SourceControlLookups\"\n                    >\n                        <mat-option\n                            [value]=\"srcCtrlLookup\"\n                            *ngIf=\"SourceControls[srcCtrlLookup]; let srcCtrl\"\n                        >\n                            {{ srcCtrl.Name }}\n                        </mat-option>\n                    </ng-container>\n                </mat-select>\n\n                <div *ngIf=\"HasBuild\">\n                    <h3>\n                        @{{\n                            SourceControlFormControls?.OrganizationFormControl\n                                ?.value || SourceControl?.Organization\n                        }}/{{\n                            SourceControlFormControls?.RepositoryFormControl\n                                ?.value || SourceControl?.Repository\n                        }}\n                    </h3>\n\n                    <p>\n                        Organization and Repository pulled from build settings\n                    </p>\n\n                    <mat-hint>\n                        CurrentBuild:\n                        {{ EditingApplication?.LowCodeUnit?.CurrentBuild }}\n                    </mat-hint>\n                </div>\n            </mat-form-field>\n\n            <div *ngIf=\"SourceControlLookups?.length < 0\">\n                <h3>\n                    Create source control locations under the DevOps tab above.\n                </h3>\n            </div>\n        </mat-card-content>\n        <mat-card-actions fxLayoutAlign=\"center center\">\n            <button\n                mat-raised-button\n                type=\"submit\"\n                fxFlex=\"100%\"\n                color=\"primary\"\n                [disabled]=\"\n                    !SourceControlFormGroup.valid ||\n                    !SourceControlFormGroup.dirty\n                \"\n            >\n                <mat-icon>save</mat-icon>\n                Save\n            </button>\n        </mat-card-actions>\n    </mat-card>\n</form>\n"]}