@lowcodeunit/applications-flow-common 1.39.86-merge → 1.39.87-enterprise-switch-fix

Sign up to get free protection for your applications and to get access to all the features.
@@ -163,7 +163,7 @@ export class DevopsSourceControlFormComponent {
163
163
  }
164
164
  RefreshOrganizations() {
165
165
  // this.Loading = true;
166
- console.log('refresh');
166
+ // console.log('refresh');
167
167
  this.listOrganizations();
168
168
  this.OrganizationFormControl?.reset();
169
169
  this.RepositoryFormControl?.reset();
@@ -408,4 +408,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
408
408
  type: ViewChild,
409
409
  args: ['branches']
410
410
  }] } });
411
- //# 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 implements OnDestroy, OnInit {\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        // console.log(\"ctor\")\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        // console.log(\"end ctor\")\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(\"on init\")\n        if (this.EditingSourceControlLookup === null) {\n            this.CreateNewSourceControl();\n        }\n\n        if (this.EditingSourceControl != null) {\n            this.DevOpsSourceControlFormGroup = this.formBuilder.group({});\n\n            this.setupFormControls();\n        }\n\n        this.RefreshOrganizations();\n        // console.log(\"end init\")\n    }\n\n    public ngOnChanges() {\n        // console.log(\"on changes\")\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[\n                            this.DevOpsActionLookup\n                        ];\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        console.log('refresh');\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        // console.log(\"saving source: \", this.EnvironmentLookup)\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>\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                    <mat-option value=\"\">-- Create New --</mat-option>\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                </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</form>\n"]}
411
+ //# 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 implements OnDestroy, OnInit {\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        // console.log(\"ctor\")\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        // console.log(\"end ctor\")\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(\"on init\")\n        if (this.EditingSourceControlLookup === null) {\n            this.CreateNewSourceControl();\n        }\n\n        if (this.EditingSourceControl != null) {\n            this.DevOpsSourceControlFormGroup = this.formBuilder.group({});\n\n            this.setupFormControls();\n        }\n\n        this.RefreshOrganizations();\n        // console.log(\"end init\")\n    }\n\n    public ngOnChanges() {\n        // console.log(\"on changes\")\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[\n                            this.DevOpsActionLookup\n                        ];\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        // console.log('refresh');\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        // console.log(\"saving source: \", this.EnvironmentLookup)\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>\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                    <mat-option value=\"\">-- Create New --</mat-option>\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                </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</form>\n"]}
@@ -92,7 +92,7 @@ export class DFSModifiersDialogComponent {
92
92
  }
93
93
  }
94
94
  SaveDFSModifier() {
95
- console.log('level at save: ', this.data.level);
95
+ // console.log('level at save: ', this.data.level);
96
96
  let status;
97
97
  switch (this.data.level) {
98
98
  case 'enterprise': {
@@ -150,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
150
150
  type: ViewChild,
151
151
  args: [DFSModifiersFormComponent]
152
152
  }] } });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dfs-modifiers-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.ts","../../../../../../projects/common/src/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { FormBuilder } from '@angular/forms';\nimport { FormGroup } from '@angular/forms';\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { Status } from '@lcu/common';\nimport { EaCApplicationAsCode } from '@semanticjs/common';\nimport { Subscription } from 'rxjs';\nimport { DFSModifiersFormComponent } from '../../controls/dfs-modifiers-form/dfs-modifiers-form.component';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\nexport interface DFSModifiersDialogData {\n    applicationLookup?: string;\n    modifierLookup?: string;\n    modifierName?: string;\n    level: string;\n    projectLookup?: string;\n}\n\n@Component({\n    selector: 'lcu-dfs-modifiers-dialog',\n    templateUrl: './dfs-modifiers-dialog.component.html',\n    styleUrls: ['./dfs-modifiers-dialog.component.scss'],\n})\nexport class DFSModifiersDialogComponent implements OnInit, OnDestroy {\n    @ViewChild(DFSModifiersFormComponent)\n    public DFSModifersFormControls: DFSModifiersFormComponent;\n\n    public get DFSModifersFormGroup(): FormGroup {\n        return this.DFSModifersFormControls?.ModifierFormGroup;\n    }\n\n    public get SelectedModifiersFormGroup(): FormGroup {\n        return this.DFSModifersFormControls?.ModifierSelectFormGroup;\n    }\n\n    public Applications: Array<EaCApplicationAsCode>;\n\n    public ErrorMessage: string;\n\n    public IsPreconfigured: boolean;\n\n    public ModifierDialogForm: FormGroup;\n\n    public SaveDisabled: boolean;\n\n    public State: ApplicationsFlowState;\n\n    public StateSub: Subscription;\n\n    public ProjectLookups: Array<string>;\n\n    constructor(\n        protected eacSvc: EaCService,\n        public formbldr: FormBuilder,\n        public dialogRef: MatDialogRef<DFSModifiersDialogComponent>,\n        @Inject(MAT_DIALOG_DATA) public data: DFSModifiersDialogData,\n        protected snackBar: MatSnackBar\n    ) {\n        this.ModifierDialogForm = this.formbldr.group({});\n    }\n\n    public ngOnInit(): void {\n        // console.log('dfs data: ', this.data);\n        this.StateSub = this.eacSvc.State.subscribe((state) => {\n            this.State = state;\n            if (this.State?.EaC?.Projects) {\n                this.ProjectLookups = Object.keys(\n                    this.State?.EaC?.Projects || {}\n                );\n            }\n        });\n        this.determineLevel();\n\n        this.IsPreconfigured = this.CheckPreconfigured();\n    }\n\n    public ngOnDestroy(): void {\n        this.StateSub.unsubscribe();\n    }\n\n    public CloseDialog() {\n        this.dialogRef.close();\n    }\n\n    public DeleteModifier(): void {\n        this.eacSvc.DeleteModifier(\n            this.data.modifierLookup,\n            this.data.modifierName\n        );\n    }\n\n    public HandleSaveFormEvent(event: Status) {\n        // console.log('event: ', event);\n        if (event.Code === 0) {\n            this.snackBar.open('DFS Modifier Saved Successfully', 'Dismiss', {\n                duration: 5000,\n            });\n            this.CloseDialog();\n        } else {\n            this.ErrorMessage = event.Message;\n        }\n    }\n\n    public IsDisabled() {\n        this.SaveDisabled = true;\n        if (this.DFSModifersFormGroup) {\n            this.SaveDisabled =\n                !this.DFSModifersFormGroup?.valid ||\n                !this.DFSModifersFormGroup?.dirty ||\n                !this.ModifierDialogForm?.valid;\n        } else if (this.SelectedModifiersFormGroup) {\n            this.SaveDisabled =\n                !this.SelectedModifiersFormGroup?.valid ||\n                !this.SelectedModifiersFormGroup?.dirty;\n        }\n        // console.log('Save disabled: ', this.SaveDisabled);\n        return this.SaveDisabled;\n    }\n\n    public CheckPreconfigured(): boolean {\n        if (this.data.modifierLookup) {\n            if (\n                this.data.modifierLookup === 'html-base' ||\n                this.data.modifierLookup === 'lcu-reg'\n            ) {\n                return true;\n            } else {\n                return false;\n            }\n        } else {\n            return false;\n        }\n    }\n\n    public SaveDFSModifier() {\n        console.log('level at save: ', this.data.level);\n\n        let status: Status;\n\n        switch (this.data.level) {\n            case 'enterprise': {\n                if (this.ModifierDialogForm.controls.applyToAllProjects.value) {\n                    //save modifier add it to the ModifierLookups of all projects\n                    status =\n                        this.DFSModifersFormControls.SaveModifierForAllProjects(\n                            this.ProjectLookups\n                        );\n                } else {\n                    //save modifier\n                    status = this.DFSModifersFormControls.SaveModifier();\n                }\n            }\n            case 'project': {\n                status = this.DFSModifersFormControls.SaveModifier(\n                    this.data.projectLookup\n                );\n            }\n\n            case 'application': {\n                status =\n                    this.DFSModifersFormControls.SaveModifierForApplication(\n                        this.data.applicationLookup\n                    );\n            }\n        }\n        if (status?.Code === 0) {\n            this.snackBar.open('DFS Modifier Saved Successfully', 'Dismiss', {\n                duration: 5000,\n            });\n        } else {\n            this.snackBar.open('DFS Modifier Failed to Save', 'Dismiss', {\n                duration: 5000,\n            });\n        }\n        // this.DFSModifersFormControls.SaveModifier();\n    }\n\n    protected determineLevel() {\n        // console.log('LEVEL: ', this.data.level);\n        switch (this.data.level.toLowerCase()) {\n            case 'enterprise': {\n                this.setupEntForm();\n            }\n        }\n    }\n\n    protected setupEntForm() {\n        this.ModifierDialogForm.addControl(\n            'applyToAllProjects',\n            this.formbldr.control(false)\n        );\n    }\n}\n","<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n    <h2 mat-dialog-title>DFS Modifiers</h2>\n\n    <button mat-icon-button (click)=\"CloseDialog()\">\n        <mat-icon>cancel</mat-icon>\n    </button>\n</div>\n\n<mat-dialog-content>\n    <lcu-dfs-modifier-form\n        [applications]=\"this.State?.EaC?.Applications\"\n        [application-lookup]=\"data.applicationLookup\"\n        [project-lookup]=\"data.projectLookup\"\n        [projects]=\"this.State?.EaC?.Projects\"\n        [editing-modifier-lookup]=\"data.modifierLookup\"\n        [level]=\"data.level\"\n        [modifiers]=\"State?.EaC?.Modifiers\"\n    >\n    </lcu-dfs-modifier-form>\n\n    <form [formGroup]=\"ModifierDialogForm\">\n        <mat-checkbox\n            *ngIf=\"data.level === 'enterprise' && data.modifierLookup\"\n            formControlName=\"applyToAllProjects\"\n            >Apply to all Projects</mat-checkbox\n        >\n    </form>\n\n    <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\">\n        {{ ErrorMessage }}\n    </mat-error>\n</mat-dialog-content>\n\n<mat-dialog-actions\n    class=\"actions-container\"\n    div\n    fxLayout=\"row\"\n    fxLayoutAlign=\"space-between center\"\n>\n    <div fxLayoutAlign=\"start center\">\n        <button\n            *ngIf=\"!IsPreconfigured\"\n            mat-raised-button\n            color=\"warn\"\n            (click)=\"DeleteModifier()\"\n            matTooltip=\"Delete {{ data.modifierLookup }}\"\n        >\n            Delete\n        </button>\n    </div>\n\n    <div fxLayoutAlign=\"end center\">\n        <button\n            class=\"action-button\"\n            mat-raised-button\n            fxFlex=\"52%\"\n            (click)=\"CloseDialog()\"\n        >\n            Cancel\n        </button>\n\n        <button\n            class=\"action-button\"\n            mat-raised-button\n            *ngIf=\"!State?.Loading\"\n            fxFlex=\"30%\"\n            color=\"primary\"\n            (click)=\"SaveDFSModifier()\"\n            [disabled]=\"IsDisabled()\"\n        >\n            Save\n        </button>\n    </div>\n</mat-dialog-actions>\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dfs-modifiers-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.ts","../../../../../../projects/common/src/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AAGhF,OAAO,EAAgB,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAKzE,OAAO,EAAE,yBAAyB,EAAE,MAAM,gEAAgE,CAAC;;;;;;;;;;;;;;AAiB3G,MAAM,OAAO,2BAA2B;IA4BpC,YACc,MAAkB,EACrB,QAAqB,EACrB,SAAoD,EAC3B,IAA4B,EAClD,QAAqB;QAJrB,WAAM,GAAN,MAAM,CAAY;QACrB,aAAQ,GAAR,QAAQ,CAAa;QACrB,cAAS,GAAT,SAAS,CAA2C;QAC3B,SAAI,GAAJ,IAAI,CAAwB;QAClD,aAAQ,GAAR,QAAQ,CAAa;QAE/B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACtD,CAAC;IAhCD,IAAW,oBAAoB;QAC3B,OAAO,IAAI,CAAC,uBAAuB,EAAE,iBAAiB,CAAC;IAC3D,CAAC;IAED,IAAW,0BAA0B;QACjC,OAAO,IAAI,CAAC,uBAAuB,EAAE,uBAAuB,CAAC;IACjE,CAAC;IA4BM,QAAQ;QACX,wCAAwC;QACxC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAClD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,QAAQ,EAAE;gBAC3B,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,IAAI,CAC7B,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,QAAQ,IAAI,EAAE,CAClC,CAAC;aACL;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,EAAE,CAAC;QAEtB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;IACrD,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAChC,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAEM,cAAc;QACjB,IAAI,CAAC,MAAM,CAAC,cAAc,CACtB,IAAI,CAAC,IAAI,CAAC,cAAc,EACxB,IAAI,CAAC,IAAI,CAAC,YAAY,CACzB,CAAC;IACN,CAAC;IAEM,mBAAmB,CAAC,KAAa;QACpC,iCAAiC;QACjC,IAAI,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE;YAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,iCAAiC,EAAE,SAAS,EAAE;gBAC7D,QAAQ,EAAE,IAAI;aACjB,CAAC,CAAC;YACH,IAAI,CAAC,WAAW,EAAE,CAAC;SACtB;aAAM;YACH,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC;SACrC;IACL,CAAC;IAEM,UAAU;QACb,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC3B,IAAI,CAAC,YAAY;gBACb,CAAC,IAAI,CAAC,oBAAoB,EAAE,KAAK;oBACjC,CAAC,IAAI,CAAC,oBAAoB,EAAE,KAAK;oBACjC,CAAC,IAAI,CAAC,kBAAkB,EAAE,KAAK,CAAC;SACvC;aAAM,IAAI,IAAI,CAAC,0BAA0B,EAAE;YACxC,IAAI,CAAC,YAAY;gBACb,CAAC,IAAI,CAAC,0BAA0B,EAAE,KAAK;oBACvC,CAAC,IAAI,CAAC,0BAA0B,EAAE,KAAK,CAAC;SAC/C;QACD,qDAAqD;QACrD,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAEM,kBAAkB;QACrB,IAAI,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YAC1B,IACI,IAAI,CAAC,IAAI,CAAC,cAAc,KAAK,WAAW;gBACxC,IAAI,CAAC,IAAI,CAAC,cAAc,KAAK,SAAS,EACxC;gBACE,OAAO,IAAI,CAAC;aACf;iBAAM;gBACH,OAAO,KAAK,CAAC;aAChB;SACJ;aAAM;YACH,OAAO,KAAK,CAAC;SAChB;IACL,CAAC;IAEM,eAAe;QAClB,mDAAmD;QAEnD,IAAI,MAAc,CAAC;QAEnB,QAAQ,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACrB,KAAK,YAAY,CAAC,CAAC;gBACf,IAAI,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,kBAAkB,CAAC,KAAK,EAAE;oBAC3D,6DAA6D;oBAC7D,MAAM;wBACF,IAAI,CAAC,uBAAuB,CAAC,0BAA0B,CACnD,IAAI,CAAC,cAAc,CACtB,CAAC;iBACT;qBAAM;oBACH,eAAe;oBACf,MAAM,GAAG,IAAI,CAAC,uBAAuB,CAAC,YAAY,EAAE,CAAC;iBACxD;aACJ;YACD,KAAK,SAAS,CAAC,CAAC;gBACZ,MAAM,GAAG,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAC9C,IAAI,CAAC,IAAI,CAAC,aAAa,CAC1B,CAAC;aACL;YAED,KAAK,aAAa,CAAC,CAAC;gBAChB,MAAM;oBACF,IAAI,CAAC,uBAAuB,CAAC,0BAA0B,CACnD,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAC9B,CAAC;aACT;SACJ;QACD,IAAI,MAAM,EAAE,IAAI,KAAK,CAAC,EAAE;YACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,iCAAiC,EAAE,SAAS,EAAE;gBAC7D,QAAQ,EAAE,IAAI;aACjB,CAAC,CAAC;SACN;aAAM;YACH,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,6BAA6B,EAAE,SAAS,EAAE;gBACzD,QAAQ,EAAE,IAAI;aACjB,CAAC,CAAC;SACN;QACD,+CAA+C;IACnD,CAAC;IAES,cAAc;QACpB,2CAA2C;QAC3C,QAAQ,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE;YACnC,KAAK,YAAY,CAAC,CAAC;gBACf,IAAI,CAAC,YAAY,EAAE,CAAC;aACvB;SACJ;IACL,CAAC;IAES,YAAY;QAClB,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAC9B,oBAAoB,EACpB,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAC/B,CAAC;IACN,CAAC;;wHAxKQ,2BAA2B,mGAgCxB,eAAe;4GAhClB,2BAA2B,yHACzB,yBAAyB,gDC1BxC,gmEA0EA;2FDjDa,2BAA2B;kBALvC,SAAS;+BACI,0BAA0B;;0BAoC/B,MAAM;2BAAC,eAAe;sEA9BpB,uBAAuB;sBAD7B,SAAS;uBAAC,yBAAyB","sourcesContent":["import { Component, Inject, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { FormBuilder } from '@angular/forms';\nimport { FormGroup } from '@angular/forms';\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { Status } from '@lcu/common';\nimport { EaCApplicationAsCode } from '@semanticjs/common';\nimport { Subscription } from 'rxjs';\nimport { DFSModifiersFormComponent } from '../../controls/dfs-modifiers-form/dfs-modifiers-form.component';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\nexport interface DFSModifiersDialogData {\n    applicationLookup?: string;\n    modifierLookup?: string;\n    modifierName?: string;\n    level: string;\n    projectLookup?: string;\n}\n\n@Component({\n    selector: 'lcu-dfs-modifiers-dialog',\n    templateUrl: './dfs-modifiers-dialog.component.html',\n    styleUrls: ['./dfs-modifiers-dialog.component.scss'],\n})\nexport class DFSModifiersDialogComponent implements OnInit, OnDestroy {\n    @ViewChild(DFSModifiersFormComponent)\n    public DFSModifersFormControls: DFSModifiersFormComponent;\n\n    public get DFSModifersFormGroup(): FormGroup {\n        return this.DFSModifersFormControls?.ModifierFormGroup;\n    }\n\n    public get SelectedModifiersFormGroup(): FormGroup {\n        return this.DFSModifersFormControls?.ModifierSelectFormGroup;\n    }\n\n    public Applications: Array<EaCApplicationAsCode>;\n\n    public ErrorMessage: string;\n\n    public IsPreconfigured: boolean;\n\n    public ModifierDialogForm: FormGroup;\n\n    public SaveDisabled: boolean;\n\n    public State: ApplicationsFlowState;\n\n    public StateSub: Subscription;\n\n    public ProjectLookups: Array<string>;\n\n    constructor(\n        protected eacSvc: EaCService,\n        public formbldr: FormBuilder,\n        public dialogRef: MatDialogRef<DFSModifiersDialogComponent>,\n        @Inject(MAT_DIALOG_DATA) public data: DFSModifiersDialogData,\n        protected snackBar: MatSnackBar\n    ) {\n        this.ModifierDialogForm = this.formbldr.group({});\n    }\n\n    public ngOnInit(): void {\n        // console.log('dfs data: ', this.data);\n        this.StateSub = this.eacSvc.State.subscribe((state) => {\n            this.State = state;\n            if (this.State?.EaC?.Projects) {\n                this.ProjectLookups = Object.keys(\n                    this.State?.EaC?.Projects || {}\n                );\n            }\n        });\n        this.determineLevel();\n\n        this.IsPreconfigured = this.CheckPreconfigured();\n    }\n\n    public ngOnDestroy(): void {\n        this.StateSub.unsubscribe();\n    }\n\n    public CloseDialog() {\n        this.dialogRef.close();\n    }\n\n    public DeleteModifier(): void {\n        this.eacSvc.DeleteModifier(\n            this.data.modifierLookup,\n            this.data.modifierName\n        );\n    }\n\n    public HandleSaveFormEvent(event: Status) {\n        // console.log('event: ', event);\n        if (event.Code === 0) {\n            this.snackBar.open('DFS Modifier Saved Successfully', 'Dismiss', {\n                duration: 5000,\n            });\n            this.CloseDialog();\n        } else {\n            this.ErrorMessage = event.Message;\n        }\n    }\n\n    public IsDisabled() {\n        this.SaveDisabled = true;\n        if (this.DFSModifersFormGroup) {\n            this.SaveDisabled =\n                !this.DFSModifersFormGroup?.valid ||\n                !this.DFSModifersFormGroup?.dirty ||\n                !this.ModifierDialogForm?.valid;\n        } else if (this.SelectedModifiersFormGroup) {\n            this.SaveDisabled =\n                !this.SelectedModifiersFormGroup?.valid ||\n                !this.SelectedModifiersFormGroup?.dirty;\n        }\n        // console.log('Save disabled: ', this.SaveDisabled);\n        return this.SaveDisabled;\n    }\n\n    public CheckPreconfigured(): boolean {\n        if (this.data.modifierLookup) {\n            if (\n                this.data.modifierLookup === 'html-base' ||\n                this.data.modifierLookup === 'lcu-reg'\n            ) {\n                return true;\n            } else {\n                return false;\n            }\n        } else {\n            return false;\n        }\n    }\n\n    public SaveDFSModifier() {\n        // console.log('level at save: ', this.data.level);\n\n        let status: Status;\n\n        switch (this.data.level) {\n            case 'enterprise': {\n                if (this.ModifierDialogForm.controls.applyToAllProjects.value) {\n                    //save modifier add it to the ModifierLookups of all projects\n                    status =\n                        this.DFSModifersFormControls.SaveModifierForAllProjects(\n                            this.ProjectLookups\n                        );\n                } else {\n                    //save modifier\n                    status = this.DFSModifersFormControls.SaveModifier();\n                }\n            }\n            case 'project': {\n                status = this.DFSModifersFormControls.SaveModifier(\n                    this.data.projectLookup\n                );\n            }\n\n            case 'application': {\n                status =\n                    this.DFSModifersFormControls.SaveModifierForApplication(\n                        this.data.applicationLookup\n                    );\n            }\n        }\n        if (status?.Code === 0) {\n            this.snackBar.open('DFS Modifier Saved Successfully', 'Dismiss', {\n                duration: 5000,\n            });\n        } else {\n            this.snackBar.open('DFS Modifier Failed to Save', 'Dismiss', {\n                duration: 5000,\n            });\n        }\n        // this.DFSModifersFormControls.SaveModifier();\n    }\n\n    protected determineLevel() {\n        // console.log('LEVEL: ', this.data.level);\n        switch (this.data.level.toLowerCase()) {\n            case 'enterprise': {\n                this.setupEntForm();\n            }\n        }\n    }\n\n    protected setupEntForm() {\n        this.ModifierDialogForm.addControl(\n            'applyToAllProjects',\n            this.formbldr.control(false)\n        );\n    }\n}\n","<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n    <h2 mat-dialog-title>DFS Modifiers</h2>\n\n    <button mat-icon-button (click)=\"CloseDialog()\">\n        <mat-icon>cancel</mat-icon>\n    </button>\n</div>\n\n<mat-dialog-content>\n    <lcu-dfs-modifier-form\n        [applications]=\"this.State?.EaC?.Applications\"\n        [application-lookup]=\"data.applicationLookup\"\n        [project-lookup]=\"data.projectLookup\"\n        [projects]=\"this.State?.EaC?.Projects\"\n        [editing-modifier-lookup]=\"data.modifierLookup\"\n        [level]=\"data.level\"\n        [modifiers]=\"State?.EaC?.Modifiers\"\n    >\n    </lcu-dfs-modifier-form>\n\n    <form [formGroup]=\"ModifierDialogForm\">\n        <mat-checkbox\n            *ngIf=\"data.level === 'enterprise' && data.modifierLookup\"\n            formControlName=\"applyToAllProjects\"\n            >Apply to all Projects</mat-checkbox\n        >\n    </form>\n\n    <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\">\n        {{ ErrorMessage }}\n    </mat-error>\n</mat-dialog-content>\n\n<mat-dialog-actions\n    class=\"actions-container\"\n    div\n    fxLayout=\"row\"\n    fxLayoutAlign=\"space-between center\"\n>\n    <div fxLayoutAlign=\"start center\">\n        <button\n            *ngIf=\"!IsPreconfigured\"\n            mat-raised-button\n            color=\"warn\"\n            (click)=\"DeleteModifier()\"\n            matTooltip=\"Delete {{ data.modifierLookup }}\"\n        >\n            Delete\n        </button>\n    </div>\n\n    <div fxLayoutAlign=\"end center\">\n        <button\n            class=\"action-button\"\n            mat-raised-button\n            fxFlex=\"52%\"\n            (click)=\"CloseDialog()\"\n        >\n            Cancel\n        </button>\n\n        <button\n            class=\"action-button\"\n            mat-raised-button\n            *ngIf=\"!State?.Loading\"\n            fxFlex=\"30%\"\n            color=\"primary\"\n            (click)=\"SaveDFSModifier()\"\n            [disabled]=\"IsDisabled()\"\n        >\n            Save\n        </button>\n    </div>\n</mat-dialog-actions>\n"]}
@@ -100,7 +100,7 @@ export class FeedHeaderComponent {
100
100
  window.location.href = path;
101
101
  }
102
102
  Submit() {
103
- console.log('submitting: ', this.value);
103
+ // console.log('submitting: ', this.value);
104
104
  switch (this.selectedBtn) {
105
105
  case 'pr-btn':
106
106
  //Pull request
@@ -154,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
154
154
  type: Input,
155
155
  args: ['loading-feed']
156
156
  }] } });
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feed-header.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/feed-header/feed-header.component.ts","../../../../../../projects/common/src/lib/elements/feed-header/feed-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { FeedHeaderDialogComponent } from '../../dialogs/feed-header-dialog/feed-header-dialog.component';\nimport { NewApplicationDialogComponent } from '../../dialogs/new-application-dialog/new-application-dialog.component';\nimport { FeedItemAction } from '../../models/user-feed.model';\nimport { EaCService } from '../../services/eac.service';\n\n@Component({\n    selector: 'lcu-feed-header',\n    templateUrl: './feed-header.component.html',\n    styleUrls: ['./feed-header.component.scss'],\n})\nexport class FeedHeaderComponent implements OnInit {\n    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    @Input('feed')\n    public Feed: any;\n\n    @Input('feed-check')\n    public FeedCheck: any;\n\n    @Input('source-control-lookup')\n    public SourceControlLookup: string;\n\n    @Input('has-gh-connection')\n    public HasGHConnection: boolean;\n\n    @Input('feed-header-actions')\n    public FeedHeaderActions: Array<FeedItemAction>;\n\n    @Input('loading-feed')\n    public LoadingFeed: boolean;\n\n    // public get ActiveEnvironmentLookup(): string {\n    //     //  TODO:  Eventually support multiple environments\n    //     const envLookups = Object.keys(this.State?.EaC?.Environments || {});\n\n    //     return envLookups[0];\n    // }\n\n    // public get FeedHeaderActions(): Array<FeedItemAction> {\n    //     // console.log('FeedActions: ', this.State?.FeedActions)\n    //     return this.State?.FeedActions;\n    // }\n\n    // public get HasGHConnection(): boolean {\n    //     return this.State?.GitHub?.HasConnection;\n    // }\n\n    // public get State(): ApplicationsFlowState {\n    //     return this.eacSvc.State;\n    // }\n\n    public ModalHeader: string;\n\n    public SkeletonEffect: string;\n\n    protected selectedBtn: string;\n\n    public value: string;\n\n    constructor(protected eacSvc: EaCService, protected dialog: MatDialog) {\n        this.SkeletonEffect = 'wave';\n        // this.selectedBtn = \"pr-btn\";\n    }\n\n    public ngOnInit(): void {}\n\n    public ngOnChanges() {\n        // console.log('feed header actions: ', this.FeedHeaderActions);\n    }\n\n    public ngAfterViewInit() {\n        this.addSelectBtn();\n    }\n\n    public CreateAnnouncement() {\n        // this.ModalHeader = \"Create Team Announcement\";\n        this.OpenFHDialog('Announcement', 'Create Team Announcement');\n    }\n\n    // public CreateFeatureBranch(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Create Feature Branch\";\n    //   this.selectedBtn = \"fb-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"create feature branch selected\");\n    //   this.OpenFHDialog('branch');\n\n    // }\n\n    // public OpenIssue(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Open Issue\";\n    //   this.selectedBtn = \"oi-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"open issue selected\");\n    //   this.OpenFHDialog('issue');\n\n    // }\n\n    // public CreatePullRequest(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Create Pull Request\";\n    //   this.selectedBtn = \"pr-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"create pull request selected\");\n    //   this.OpenFHDialog('pull-request');\n\n    // }\n\n    public CreateNewApp() {\n        const dialogRef = this.dialog.open(NewApplicationDialogComponent, {\n            width: '600px',\n            data: {\n                environmentLookup: this.ActiveEnvironmentLookup,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result: any) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public HandleAction(action: FeedItemAction) {\n        if (action.ActionType == 'Link') {\n            if (action.Action.startsWith('http')) {\n                window.open(action.Action, '_blank');\n            } else {\n                window.location.href = action.Action;\n            }\n        } else if (action.ActionType == 'Modal') {\n            this.OpenFHDialog(action.Action, action.Text);\n        }\n    }\n\n    public OpenFHDialog(modalType: string, modalHeader: string) {\n        const dialogRef = this.dialog.open(FeedHeaderDialogComponent, {\n            width: '600px',\n            data: {\n                dialogTitle: modalHeader,\n                type: modalType,\n                sourceControlLookup: this.SourceControlLookup\n                    ? this.SourceControlLookup\n                    : null,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result: any) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public ReloadFeed(): void {\n        this.eacSvc.ReloadFeed();\n    }\n\n    public RouteToPath(path: string): void {\n        window.location.href = path;\n    }\n\n    public Submit() {\n        console.log('submitting: ', this.value);\n        switch (this.selectedBtn) {\n            case 'pr-btn':\n                //Pull request\n                // console.log('creating pull request: ', this.value);\n                break;\n            case 'oi-btn':\n                //Open Issue\n                // console.log('Open issue: ', this.value);\n                break;\n            case 'fb-btn':\n                //Feature Branch\n                // console.log('creating feature branch: ', this.value);\n                break;\n            default:\n                // console.log('hmm');\n\n                break;\n        }\n    }\n\n    //HELPERS\n\n    protected addSelectBtn() {\n        (<HTMLElement>document.getElementById(this.selectedBtn))?.classList.add(\n            'selected'\n        );\n    }\n\n    protected removeSelectedBtn() {\n        (<HTMLElement>(\n            document.getElementById(this.selectedBtn)\n        ))?.classList.remove('selected');\n    }\n}\n","<div>\n    <mat-card class=\"social-card\">\n        <ng-container *ngIf=\"!LoadingFeed && Feed\">\n            <!-- COMMENTED OUT ANNOUNCEMENT BUTTON -->\n            <!-- <div\n                class=\"gh-card-container\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"center center\"\n            >\n                <mat-icon fxFlex=\"15%\" class=\"gh-icon\" color=\"primary\">\n                    campaign\n                </mat-icon>\n                <div fxFlex=\"85%\" class=\"gh-card-main-content\">\n                    <button\n                        mat-raised-button\n                        class=\"main-btn\"\n                        (click)=\"CreateAnnouncement()\"\n                        color=\"primary\"\n                    >\n                        Create Team Announcement\n                    </button>\n\n                </div>\n\n            </div> -->\n\n            <mat-card-actions\n                class=\"feed-header-actions\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"space-around center\"\n            >\n                <ng-container *ngFor=\"let action of FeedHeaderActions\">\n                    <ng-container *ngIf=\"FeedHeaderActions?.length > 2\">\n                        <button\n                            mat-raised-button\n                            [color]=\"action.Color\"\n                            (click)=\"HandleAction(action)\"\n                            class=\"action-btn-sm\"\n                            fxLayoutAlign=\"center center\"\n                        >\n                            <div\n                                fxLayout.gt-md=\"row\"\n                                fxLayout.lt-md=\"column\"\n                                fxLayoutAlign=\"center center\"\n                            >\n                                <mat-icon *ngIf=\"action.Icon\">{{\n                                    action.Icon\n                                }}</mat-icon>\n\n                                <div class=\"action-text\">{{ action.Text }}</div>\n                            </div>\n                        </button>\n                    </ng-container>\n                    <ng-container *ngIf=\"FeedHeaderActions?.length <= 2\">\n                        <button\n                            mat-raised-button\n                            [color]=\"action.Color\"\n                            (click)=\"HandleAction(action)\"\n                            class=\"action-btn-lg\"\n                            fxLayout=\"row\"\n                            fxLayoutAlign=\"center center\"\n                        >\n                            <div\n                                fxLayout.gt-md=\"row\"\n                                fxLayout.lt-md=\"column\"\n                                fxLayoutAlign=\"center center\"\n                            >\n                                <mat-icon *ngIf=\"action.Icon\">{{\n                                    action.Icon\n                                }}</mat-icon>\n                                <div class=\"action-text\">\n                                    {{ action.Text }}\n                                </div>\n                            </div>\n                        </button>\n                    </ng-container>\n                </ng-container>\n            </mat-card-actions>\n        </ng-container>\n\n        <!-- SKELETON -->\n        <ng-container *ngIf=\"LoadingFeed || !Feed\">\n            <!-- COMMENTED OUT SKELETON  FOR ANNOUNCEMENT BTN -->\n            <!-- <div\n                id=\"gh-card-skeleton\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"center center\"\n            >\n                <skeleton-avatar\n                    class=\"gh-icon\"\n                    [showIcon]=\"false\"\n                    [effect]=\"SkeletonEffect\"\n                ></skeleton-avatar>\n\n                <div fxFlex=\"85%\" class=\"gh-card-main-content\">\n                    <skeleton-block\n                        height=\"60px\"\n                        [effect]=\"SkeletonEffect\"\n                    ></skeleton-block>\n                </div>\n\n               \n            </div> -->\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n                <div skeleton-text [effect]=\"SkeletonEffect\">Pull Request</div>\n                <div skeleton-text [effect]=\"SkeletonEffect\">Open Issue</div>\n                <div skeleton-text [effect]=\"SkeletonEffect\">\n                    Feature Branch\n                </div>\n            </div>\n        </ng-container>\n    </mat-card>\n    <!-- <mat-card\n        class=\"social-card reload\"\n        *ngIf=\"FeedCheck\"\n        fxLayout=\"row\"\n        fxLayoutAlign=\"center center\"\n    >\n        <div>There are new items in your feed.</div>\n\n        <button mat-raised-button (click)=\"ReloadFeed()\">Reload Feed</button>\n    </mat-card> -->\n</div>\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feed-header.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/feed-header/feed-header.component.ts","../../../../../../projects/common/src/lib/elements/feed-header/feed-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { FeedHeaderDialogComponent } from '../../dialogs/feed-header-dialog/feed-header-dialog.component';\nimport { NewApplicationDialogComponent } from '../../dialogs/new-application-dialog/new-application-dialog.component';\nimport { FeedItemAction } from '../../models/user-feed.model';\nimport { EaCService } from '../../services/eac.service';\n\n@Component({\n    selector: 'lcu-feed-header',\n    templateUrl: './feed-header.component.html',\n    styleUrls: ['./feed-header.component.scss'],\n})\nexport class FeedHeaderComponent implements OnInit {\n    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    @Input('feed')\n    public Feed: any;\n\n    @Input('feed-check')\n    public FeedCheck: any;\n\n    @Input('source-control-lookup')\n    public SourceControlLookup: string;\n\n    @Input('has-gh-connection')\n    public HasGHConnection: boolean;\n\n    @Input('feed-header-actions')\n    public FeedHeaderActions: Array<FeedItemAction>;\n\n    @Input('loading-feed')\n    public LoadingFeed: boolean;\n\n    // public get ActiveEnvironmentLookup(): string {\n    //     //  TODO:  Eventually support multiple environments\n    //     const envLookups = Object.keys(this.State?.EaC?.Environments || {});\n\n    //     return envLookups[0];\n    // }\n\n    // public get FeedHeaderActions(): Array<FeedItemAction> {\n    //     // console.log('FeedActions: ', this.State?.FeedActions)\n    //     return this.State?.FeedActions;\n    // }\n\n    // public get HasGHConnection(): boolean {\n    //     return this.State?.GitHub?.HasConnection;\n    // }\n\n    // public get State(): ApplicationsFlowState {\n    //     return this.eacSvc.State;\n    // }\n\n    public ModalHeader: string;\n\n    public SkeletonEffect: string;\n\n    protected selectedBtn: string;\n\n    public value: string;\n\n    constructor(protected eacSvc: EaCService, protected dialog: MatDialog) {\n        this.SkeletonEffect = 'wave';\n        // this.selectedBtn = \"pr-btn\";\n    }\n\n    public ngOnInit(): void {}\n\n    public ngOnChanges() {\n        // console.log('feed header actions: ', this.FeedHeaderActions);\n    }\n\n    public ngAfterViewInit() {\n        this.addSelectBtn();\n    }\n\n    public CreateAnnouncement() {\n        // this.ModalHeader = \"Create Team Announcement\";\n        this.OpenFHDialog('Announcement', 'Create Team Announcement');\n    }\n\n    // public CreateFeatureBranch(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Create Feature Branch\";\n    //   this.selectedBtn = \"fb-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"create feature branch selected\");\n    //   this.OpenFHDialog('branch');\n\n    // }\n\n    // public OpenIssue(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Open Issue\";\n    //   this.selectedBtn = \"oi-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"open issue selected\");\n    //   this.OpenFHDialog('issue');\n\n    // }\n\n    // public CreatePullRequest(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Create Pull Request\";\n    //   this.selectedBtn = \"pr-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"create pull request selected\");\n    //   this.OpenFHDialog('pull-request');\n\n    // }\n\n    public CreateNewApp() {\n        const dialogRef = this.dialog.open(NewApplicationDialogComponent, {\n            width: '600px',\n            data: {\n                environmentLookup: this.ActiveEnvironmentLookup,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result: any) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public HandleAction(action: FeedItemAction) {\n        if (action.ActionType == 'Link') {\n            if (action.Action.startsWith('http')) {\n                window.open(action.Action, '_blank');\n            } else {\n                window.location.href = action.Action;\n            }\n        } else if (action.ActionType == 'Modal') {\n            this.OpenFHDialog(action.Action, action.Text);\n        }\n    }\n\n    public OpenFHDialog(modalType: string, modalHeader: string) {\n        const dialogRef = this.dialog.open(FeedHeaderDialogComponent, {\n            width: '600px',\n            data: {\n                dialogTitle: modalHeader,\n                type: modalType,\n                sourceControlLookup: this.SourceControlLookup\n                    ? this.SourceControlLookup\n                    : null,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result: any) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public ReloadFeed(): void {\n        this.eacSvc.ReloadFeed();\n    }\n\n    public RouteToPath(path: string): void {\n        window.location.href = path;\n    }\n\n    public Submit() {\n        // console.log('submitting: ', this.value);\n        switch (this.selectedBtn) {\n            case 'pr-btn':\n                //Pull request\n                // console.log('creating pull request: ', this.value);\n                break;\n            case 'oi-btn':\n                //Open Issue\n                // console.log('Open issue: ', this.value);\n                break;\n            case 'fb-btn':\n                //Feature Branch\n                // console.log('creating feature branch: ', this.value);\n                break;\n            default:\n                // console.log('hmm');\n\n                break;\n        }\n    }\n\n    //HELPERS\n\n    protected addSelectBtn() {\n        (<HTMLElement>document.getElementById(this.selectedBtn))?.classList.add(\n            'selected'\n        );\n    }\n\n    protected removeSelectedBtn() {\n        (<HTMLElement>(\n            document.getElementById(this.selectedBtn)\n        ))?.classList.remove('selected');\n    }\n}\n","<div>\n    <mat-card class=\"social-card\">\n        <ng-container *ngIf=\"!LoadingFeed && Feed\">\n            <!-- COMMENTED OUT ANNOUNCEMENT BUTTON -->\n            <!-- <div\n                class=\"gh-card-container\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"center center\"\n            >\n                <mat-icon fxFlex=\"15%\" class=\"gh-icon\" color=\"primary\">\n                    campaign\n                </mat-icon>\n                <div fxFlex=\"85%\" class=\"gh-card-main-content\">\n                    <button\n                        mat-raised-button\n                        class=\"main-btn\"\n                        (click)=\"CreateAnnouncement()\"\n                        color=\"primary\"\n                    >\n                        Create Team Announcement\n                    </button>\n\n                </div>\n\n            </div> -->\n\n            <mat-card-actions\n                class=\"feed-header-actions\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"space-around center\"\n            >\n                <ng-container *ngFor=\"let action of FeedHeaderActions\">\n                    <ng-container *ngIf=\"FeedHeaderActions?.length > 2\">\n                        <button\n                            mat-raised-button\n                            [color]=\"action.Color\"\n                            (click)=\"HandleAction(action)\"\n                            class=\"action-btn-sm\"\n                            fxLayoutAlign=\"center center\"\n                        >\n                            <div\n                                fxLayout.gt-md=\"row\"\n                                fxLayout.lt-md=\"column\"\n                                fxLayoutAlign=\"center center\"\n                            >\n                                <mat-icon *ngIf=\"action.Icon\">{{\n                                    action.Icon\n                                }}</mat-icon>\n\n                                <div class=\"action-text\">{{ action.Text }}</div>\n                            </div>\n                        </button>\n                    </ng-container>\n                    <ng-container *ngIf=\"FeedHeaderActions?.length <= 2\">\n                        <button\n                            mat-raised-button\n                            [color]=\"action.Color\"\n                            (click)=\"HandleAction(action)\"\n                            class=\"action-btn-lg\"\n                            fxLayout=\"row\"\n                            fxLayoutAlign=\"center center\"\n                        >\n                            <div\n                                fxLayout.gt-md=\"row\"\n                                fxLayout.lt-md=\"column\"\n                                fxLayoutAlign=\"center center\"\n                            >\n                                <mat-icon *ngIf=\"action.Icon\">{{\n                                    action.Icon\n                                }}</mat-icon>\n                                <div class=\"action-text\">\n                                    {{ action.Text }}\n                                </div>\n                            </div>\n                        </button>\n                    </ng-container>\n                </ng-container>\n            </mat-card-actions>\n        </ng-container>\n\n        <!-- SKELETON -->\n        <ng-container *ngIf=\"LoadingFeed || !Feed\">\n            <!-- COMMENTED OUT SKELETON  FOR ANNOUNCEMENT BTN -->\n            <!-- <div\n                id=\"gh-card-skeleton\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"center center\"\n            >\n                <skeleton-avatar\n                    class=\"gh-icon\"\n                    [showIcon]=\"false\"\n                    [effect]=\"SkeletonEffect\"\n                ></skeleton-avatar>\n\n                <div fxFlex=\"85%\" class=\"gh-card-main-content\">\n                    <skeleton-block\n                        height=\"60px\"\n                        [effect]=\"SkeletonEffect\"\n                    ></skeleton-block>\n                </div>\n\n               \n            </div> -->\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n                <div skeleton-text [effect]=\"SkeletonEffect\">Pull Request</div>\n                <div skeleton-text [effect]=\"SkeletonEffect\">Open Issue</div>\n                <div skeleton-text [effect]=\"SkeletonEffect\">\n                    Feature Branch\n                </div>\n            </div>\n        </ng-container>\n    </mat-card>\n    <!-- <mat-card\n        class=\"social-card reload\"\n        *ngIf=\"FeedCheck\"\n        fxLayout=\"row\"\n        fxLayoutAlign=\"center center\"\n    >\n        <div>There are new items in your feed.</div>\n\n        <button mat-raised-button (click)=\"ReloadFeed()\">Reload Feed</button>\n    </mat-card> -->\n</div>\n"]}