@lowcodeunit/applications-flow-common 1.39.37-hardening-bugs → 1.39.39-hardening-bugs

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -47,9 +47,9 @@ export class BreadcrumbComponent {
47
47
  if (this.RoutedApplications &&
48
48
  Object.keys(this.RoutedApplications)?.length !== 0) {
49
49
  this.Routes = Object.keys(this.RoutedApplications || {});
50
- console.log('routed apps: ', this.RoutedApplications);
50
+ // console.log('routed apps: ', this.RoutedApplications);
51
51
  if (this.SelectedRoute) {
52
- console.log('selected route: ', this.SelectedRoute);
52
+ // console.log('selected route: ', this.SelectedRoute);
53
53
  this.CurrentRouteApplicationLookups =
54
54
  Object.keys(this.RoutedApplications[this.SelectedRoute]) ||
55
55
  [];
@@ -141,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
141
141
  type: Input,
142
142
  args: ['applications-bank']
143
143
  }] } });
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/breadcrumb/breadcrumb.component.ts","../../../../../../projects/common/src/lib/elements/breadcrumb/breadcrumb.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\nimport { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { EaCApplicationAsCode, EaCProjectAsCode } from '@semanticjs/common';\nimport { Subscribable, Subscription } from 'rxjs';\nimport { EaCService } from '../../services/eac.service';\n\n@Component({\n    selector: 'lcu-breadcrumb',\n    templateUrl: './breadcrumb.component.html',\n    styleUrls: ['./breadcrumb.component.scss'],\n})\nexport class BreadcrumbComponent implements OnInit, OnDestroy {\n    @Input('application-lookup')\n    public ApplicationLookup: string;\n\n    @Input('enterprise')\n    public Enterprise: any;\n\n    @Input('enterprises')\n    public Enterprises: Array<any>;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Input('projects')\n    public Projects: any;\n\n    @Input('project-lookup')\n    public ProjectLookup: string;\n\n    @Input('routed-application')\n    public RoutedApplications: {\n        [route: string]: { [lookup: string]: EaCApplicationAsCode };\n    };\n\n    @Input('selected-route')\n    public SelectedRoute: string;\n\n    @Input('applications-bank')\n    public ApplicationsBank: { [lookup: string]: EaCApplicationAsCode };\n\n    public Applications: { [lookup: string]: EaCApplicationAsCode };\n\n    public BPSub: Subscription;\n\n    public CurrentLevel: string;\n\n    public CurrentRouteApplicationLookups: Array<string>;\n\n    public IsSmScreen: boolean;\n\n    public ReturnRouterLink: any;\n\n    public Routes: Array<string>;\n\n    public SelectedProject: EaCProjectAsCode;\n\n    public SkeletonEffect: string;\n\n    public SelectedApplication: EaCApplicationAsCode;\n\n    public ProjectLookups: Array<string>;\n\n    constructor(\n        protected eacSvc: EaCService,\n        public breakpointObserver: BreakpointObserver\n    ) {\n        this.SkeletonEffect = 'wave';\n    }\n\n    ngOnInit(): void {\n        this.BPSub = this.breakpointObserver\n            .observe(['(max-width: 959px)'])\n            .subscribe((state: BreakpointState) => {\n                if (state.matches) {\n                    this.IsSmScreen = true;\n                } else {\n                    this.IsSmScreen = false;\n                }\n                console.log('small: ', this.IsSmScreen);\n\n                if (this.IsSmScreen) {\n                    this.CurrentLevel = this.determineCurrentLevel();\n\n                    this.ReturnRouterLink = this.determineReturnRouterLink();\n                }\n            });\n    }\n\n    ngOnChanges() {\n        if (this.ApplicationsBank && this.ApplicationLookup) {\n            this.SelectedApplication =\n                this.ApplicationsBank[this.ApplicationLookup];\n        }\n\n        if (this.Projects) {\n            this.ProjectLookups = Object.keys(this.Projects || {});\n\n            if (this.ProjectLookup) {\n                this.SelectedProject = this.Projects[this.ProjectLookup];\n            }\n        }\n\n        if (\n            this.RoutedApplications &&\n            Object.keys(this.RoutedApplications)?.length !== 0\n        ) {\n            this.Routes = Object.keys(this.RoutedApplications || {});\n\n            console.log('routed apps: ', this.RoutedApplications);\n\n            if (this.SelectedRoute) {\n                console.log('selected route: ', this.SelectedRoute);\n\n                this.CurrentRouteApplicationLookups =\n                    Object.keys(this.RoutedApplications[this.SelectedRoute]) ||\n                    [];\n            }\n        }\n\n        if (this.SelectedProject && this.ApplicationsBank) {\n            this.Applications = {};\n\n            this.SelectedProject?.ApplicationLookups?.forEach(\n                (appLookup: string) => {\n                    this.Applications[appLookup] =\n                        this.ApplicationsBank[appLookup];\n                }\n            );\n        }\n\n        if (this.IsSmScreen) {\n            this.CurrentLevel = this.determineCurrentLevel();\n\n            this.ReturnRouterLink = this.determineReturnRouterLink();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.BPSub.unsubscribe();\n    }\n\n    public SetActiveEnterprise(entLookup: string): void {\n        this.eacSvc.SetActiveEnterprise(entLookup).then(() => {});\n    }\n\n    protected determineCurrentLevel(): string {\n        let lastLevel: string;\n        if (this.Enterprise) {\n            lastLevel = 'ent';\n        }\n        if (this.ProjectLookup) {\n            lastLevel = 'project';\n        }\n        if (this.SelectedRoute) {\n            lastLevel = 'route';\n        }\n        if (this.SelectedApplication) {\n            lastLevel = 'app';\n        }\n        return lastLevel;\n    }\n\n    protected determineReturnRouterLink(): any {\n        let rLink;\n        if (this.Enterprise) {\n            rLink = null;\n        }\n        if (this.ProjectLookup) {\n            rLink = ['/enterprise'];\n        }\n        if (this.SelectedRoute) {\n            rLink = ['/project', this.ProjectLookup];\n        }\n        if (this.SelectedApplication) {\n            // rLink = ['/project', this.ProjectLookup];\n\n            rLink = ['/route', this.SelectedRoute, this.ProjectLookup];\n        }\n        console.log('rlink: ', rLink);\n        return rLink;\n    }\n\n    // protected async handleStateChange(): Promise<void> {}\n}\n","<div class=\"breadcrumb-container\" *ngIf=\"!IsSmScreen\" fxLayout=\"row wrap\">\n    <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n        <ng-container *ngIf=\"Loading\">\n            <!-- <mat-icon skeleton-text [effect]=\"SkeletonEffect\">home</mat-icon> -->\n\n            <div skeleton-text [effect]=\"SkeletonEffect\">Enterprise Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"Enterprise && !Loading\">\n            <div class=\"crumb-name\" [routerLink]=\"['/enterprise']\">\n                {{ Enterprise?.Name }}\n            </div>\n\n            <button mat-icon-button [matMenuTriggerFor]=\"enterpriseMenu\">\n                <mat-icon>expand_more</mat-icon>\n            </button>\n\n            <mat-menu #enterpriseMenu=\"matMenu\" xPosition=\"before\">\n                <button\n                    mat-menu-item\n                    [routerLink]=\"['/enterprise']\"\n                    (click)=\"SetActiveEnterprise(ent.Lookup)\"\n                    *ngFor=\"let ent of Enterprises\"\n                    [matTooltip]=\"ent.Name\"\n                >\n                    <span>{{ ent.Name }}</span>\n                </button>\n            </mat-menu>\n        </ng-container>\n    </div>\n\n    <div\n        *ngIf=\"ProjectLookup && SelectedProject\"\n        fxLayout=\"row\"\n        fxLayoutAlign=\"center center\"\n    >\n        <span class=\"seperator\">/</span>\n\n        <ng-container *ngIf=\"Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Project Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!Loading\">\n            <div class=\"crumb-name\" [routerLink]=\"['/project', ProjectLookup]\">\n                {{ SelectedProject?.Project?.Name }}\n            </div>\n\n            <button mat-icon-button [matMenuTriggerFor]=\"projectMenu\">\n                <mat-icon>expand_more</mat-icon>\n            </button>\n\n            <mat-menu #projectMenu=\"matMenu\" xPosition=\"before\">\n                <ng-container *ngFor=\"let projectLookup of ProjectLookups\">\n                    <button\n                        mat-menu-item\n                        *ngIf=\"Projects[projectLookup]; let pro\"\n                        [matTooltip]=\"pro.Project?.Name\"\n                        [routerLink]=\"['/project', projectLookup]\"\n                    >\n                        <span>{{ pro.Project?.Name }}</span>\n                    </button>\n                </ng-container>\n            </mat-menu>\n        </ng-container>\n    </div>\n\n    <div *ngIf=\"SelectedRoute\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n        <span class=\"seperator\">/</span>\n\n        <ng-container *ngIf=\"Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Route Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!Loading\">\n            <div\n                class=\"crumb-name\"\n                [routerLink]=\"['/route', SelectedRoute, ProjectLookup]\"\n            >\n                {{ SelectedRoute }}\n            </div>\n\n            <button mat-icon-button [matMenuTriggerFor]=\"routeMenu\">\n                <mat-icon>expand_more</mat-icon>\n            </button>\n\n            <mat-menu #routeMenu=\"matMenu\" xPosition=\"before\">\n                <ng-container *ngFor=\"let appRoute of Routes\">\n                    <button\n                        mat-menu-item\n                        [routerLink]=\"['/route', appRoute, ProjectLookup]\"\n                        [matTooltip]=\"appRoute\"\n                    >\n                        <span *ngIf=\"appRoute\">{{ appRoute }}</span>\n                    </button>\n                </ng-container>\n            </mat-menu>\n        </ng-container>\n    </div>\n\n    <div\n        *ngIf=\"SelectedApplication && ApplicationLookup\"\n        fxLayout=\"row\"\n        fxLayoutAlign=\"center center\"\n    >\n        <span class=\"seperator\">/</span>\n\n        <ng-container *ngIf=\"Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Application Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!Loading\">\n            <div\n                class=\"crumb-name\"\n                [routerLink]=\"[\n                    '/application',\n                    ApplicationLookup,\n                    SelectedRoute,\n                    ProjectLookup\n                ]\"\n            >\n                {{ SelectedApplication?.Application?.Name }}\n            </div>\n\n            <button mat-icon-button [matMenuTriggerFor]=\"applicationMenu\">\n                <mat-icon>expand_more</mat-icon>\n            </button>\n\n            <mat-menu #applicationMenu=\"matMenu\" xPosition=\"before\">\n                <ng-container\n                    *ngFor=\"let appLookup of CurrentRouteApplicationLookups\"\n                >\n                    <button\n                        mat-menu-item\n                        [routerLink]=\"[\n                            '/application',\n                            appLookup,\n                            SelectedRoute,\n                            ProjectLookup\n                        ]\"\n                        *ngIf=\"\n                            RoutedApplications[SelectedRoute][appLookup];\n                            let app\n                        \"\n                        [matTooltip]=\"app.Application?.Name\"\n                    >\n                        <span>{{ app.Application?.Name }}</span>\n                    </button>\n                </ng-container>\n            </mat-menu>\n        </ng-container>\n    </div>\n</div>\n\n<!-- MOBILE VIEW -->\n\n<div\n    class=\"breadcrumb-container\"\n    *ngIf=\"IsSmScreen\"\n    fxLayout=\"row\"\n    fxLayoutAlign=\"start center\"\n>\n    <ng-container *ngIf=\"Loading\">\n        <mat-icon skeleton-text [effect]=\"SkeletonEffect\"\n            >chevron_left</mat-icon\n        >\n\n        <div skeleton-text [effect]=\"SkeletonEffect\">Current Path</div>\n\n        <mat-icon skeleton-text [effect]=\"SkeletonEffect\">expand_more</mat-icon>\n    </ng-container>\n\n    <ng-container *ngIf=\"!Loading\">\n        <button\n            *ngIf=\"ReturnRouterLink\"\n            mat-icon-button\n            [routerLink]=\"ReturnRouterLink\"\n        >\n            <mat-icon>chevron_left</mat-icon>\n        </button>\n        <ng-container [ngSwitch]=\"CurrentLevel\">\n            <ng-container *ngSwitchCase=\"'ent'\">\n                <div class=\"crumb-name\" [routerLink]=\"['/enterprise']\">\n                    <!-- <mat-icon>home</mat-icon> -->\n\n                    {{ Enterprise?.Name }}\n                </div>\n\n                <button mat-icon-button [matMenuTriggerFor]=\"enterpriseMenu\">\n                    <mat-icon>expand_more</mat-icon>\n                </button>\n\n                <mat-menu #enterpriseMenu=\"matMenu\" xPosition=\"before\">\n                    <button\n                        mat-menu-item\n                        [routerLink]=\"['/enterprise']\"\n                        (click)=\"SetActiveEnterprise(ent.Lookup)\"\n                        *ngFor=\"let ent of Enterprises\"\n                    >\n                        <span>{{ ent.Name }}</span>\n                    </button>\n                </mat-menu>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'project'\">\n                <div\n                    class=\"crumb-name\"\n                    [routerLink]=\"['/project', ProjectLookup]\"\n                >\n                    {{ SelectedProject?.Project?.Name }}\n                </div>\n\n                <button mat-icon-button [matMenuTriggerFor]=\"projectMenu\">\n                    <mat-icon>expand_more</mat-icon>\n                </button>\n\n                <mat-menu #projectMenu=\"matMenu\" xPosition=\"before\">\n                    <button\n                        mat-menu-item\n                        *ngFor=\"let projectLookup of ProjectLookups\"\n                        [routerLink]=\"['/project', projectLookup]\"\n                    >\n                        <span *ngIf=\"Projects[projectLookup]; let pro\">{{\n                            pro.Project?.Name\n                        }}</span>\n                    </button>\n                </mat-menu>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'route'\">\n                <div\n                    class=\"crumb-name\"\n                    [routerLink]=\"['/route', SelectedRoute, ProjectLookup]\"\n                >\n                    {{ SelectedRoute }}\n                </div>\n\n                <button mat-icon-button [matMenuTriggerFor]=\"routeMenu\">\n                    <mat-icon>expand_more</mat-icon>\n                </button>\n\n                <mat-menu #routeMenu=\"matMenu\" xPosition=\"before\">\n                    <button\n                        mat-menu-item\n                        *ngFor=\"let appRoute of Routes\"\n                        [routerLink]=\"['/route', appRoute, ProjectLookup]\"\n                    >\n                        <span *ngIf=\"appRoute\">{{ appRoute }}</span>\n                    </button>\n                </mat-menu>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'app'\">\n                <div\n                    class=\"crumb-name\"\n                    [routerLink]=\"[\n                        '/application',\n                        ApplicationLookup,\n                        SelectedRoute,\n                        ProjectLookup\n                    ]\"\n                >\n                    {{ SelectedApplication?.Application?.Name }}\n                </div>\n                <button mat-icon-button [matMenuTriggerFor]=\"applicationMenu\">\n                    <mat-icon>expand_more</mat-icon>\n                </button>\n\n                <mat-menu #applicationMenu=\"matMenu\" xPosition=\"before\">\n                    <button\n                        mat-menu-item\n                        *ngFor=\"let appLookup of CurrentRouteApplicationLookups\"\n                        [routerLink]=\"[\n                            '/application',\n                            appLookup,\n                            SelectedRoute,\n                            ProjectLookup\n                        ]\"\n                    >\n                        <span\n                            *ngIf=\"\n                                RoutedApplications[SelectedRoute][appLookup];\n                                let app\n                            \"\n                            >{{ app.Application?.Name }}</span\n                        >\n                    </button>\n                </mat-menu>\n            </ng-container>\n        </ng-container>\n    </ng-container>\n</div>\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/breadcrumb/breadcrumb.component.ts","../../../../../../projects/common/src/lib/elements/breadcrumb/breadcrumb.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\nimport { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { EaCApplicationAsCode, EaCProjectAsCode } from '@semanticjs/common';\nimport { Subscribable, Subscription } from 'rxjs';\nimport { EaCService } from '../../services/eac.service';\n\n@Component({\n    selector: 'lcu-breadcrumb',\n    templateUrl: './breadcrumb.component.html',\n    styleUrls: ['./breadcrumb.component.scss'],\n})\nexport class BreadcrumbComponent implements OnInit, OnDestroy {\n    @Input('application-lookup')\n    public ApplicationLookup: string;\n\n    @Input('enterprise')\n    public Enterprise: any;\n\n    @Input('enterprises')\n    public Enterprises: Array<any>;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Input('projects')\n    public Projects: any;\n\n    @Input('project-lookup')\n    public ProjectLookup: string;\n\n    @Input('routed-application')\n    public RoutedApplications: {\n        [route: string]: { [lookup: string]: EaCApplicationAsCode };\n    };\n\n    @Input('selected-route')\n    public SelectedRoute: string;\n\n    @Input('applications-bank')\n    public ApplicationsBank: { [lookup: string]: EaCApplicationAsCode };\n\n    public Applications: { [lookup: string]: EaCApplicationAsCode };\n\n    public BPSub: Subscription;\n\n    public CurrentLevel: string;\n\n    public CurrentRouteApplicationLookups: Array<string>;\n\n    public IsSmScreen: boolean;\n\n    public ReturnRouterLink: any;\n\n    public Routes: Array<string>;\n\n    public SelectedProject: EaCProjectAsCode;\n\n    public SkeletonEffect: string;\n\n    public SelectedApplication: EaCApplicationAsCode;\n\n    public ProjectLookups: Array<string>;\n\n    constructor(\n        protected eacSvc: EaCService,\n        public breakpointObserver: BreakpointObserver\n    ) {\n        this.SkeletonEffect = 'wave';\n    }\n\n    ngOnInit(): void {\n        this.BPSub = this.breakpointObserver\n            .observe(['(max-width: 959px)'])\n            .subscribe((state: BreakpointState) => {\n                if (state.matches) {\n                    this.IsSmScreen = true;\n                } else {\n                    this.IsSmScreen = false;\n                }\n                console.log('small: ', this.IsSmScreen);\n\n                if (this.IsSmScreen) {\n                    this.CurrentLevel = this.determineCurrentLevel();\n\n                    this.ReturnRouterLink = this.determineReturnRouterLink();\n                }\n            });\n    }\n\n    ngOnChanges() {\n        if (this.ApplicationsBank && this.ApplicationLookup) {\n            this.SelectedApplication =\n                this.ApplicationsBank[this.ApplicationLookup];\n        }\n\n        if (this.Projects) {\n            this.ProjectLookups = Object.keys(this.Projects || {});\n\n            if (this.ProjectLookup) {\n                this.SelectedProject = this.Projects[this.ProjectLookup];\n            }\n        }\n\n        if (\n            this.RoutedApplications &&\n            Object.keys(this.RoutedApplications)?.length !== 0\n        ) {\n            this.Routes = Object.keys(this.RoutedApplications || {});\n\n            // console.log('routed apps: ', this.RoutedApplications);\n\n            if (this.SelectedRoute) {\n                // console.log('selected route: ', this.SelectedRoute);\n\n                this.CurrentRouteApplicationLookups =\n                    Object.keys(this.RoutedApplications[this.SelectedRoute]) ||\n                    [];\n            }\n        }\n\n        if (this.SelectedProject && this.ApplicationsBank) {\n            this.Applications = {};\n\n            this.SelectedProject?.ApplicationLookups?.forEach(\n                (appLookup: string) => {\n                    this.Applications[appLookup] =\n                        this.ApplicationsBank[appLookup];\n                }\n            );\n        }\n\n        if (this.IsSmScreen) {\n            this.CurrentLevel = this.determineCurrentLevel();\n\n            this.ReturnRouterLink = this.determineReturnRouterLink();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.BPSub.unsubscribe();\n    }\n\n    public SetActiveEnterprise(entLookup: string): void {\n        this.eacSvc.SetActiveEnterprise(entLookup).then(() => {});\n    }\n\n    protected determineCurrentLevel(): string {\n        let lastLevel: string;\n        if (this.Enterprise) {\n            lastLevel = 'ent';\n        }\n        if (this.ProjectLookup) {\n            lastLevel = 'project';\n        }\n        if (this.SelectedRoute) {\n            lastLevel = 'route';\n        }\n        if (this.SelectedApplication) {\n            lastLevel = 'app';\n        }\n        return lastLevel;\n    }\n\n    protected determineReturnRouterLink(): any {\n        let rLink;\n        if (this.Enterprise) {\n            rLink = null;\n        }\n        if (this.ProjectLookup) {\n            rLink = ['/enterprise'];\n        }\n        if (this.SelectedRoute) {\n            rLink = ['/project', this.ProjectLookup];\n        }\n        if (this.SelectedApplication) {\n            // rLink = ['/project', this.ProjectLookup];\n\n            rLink = ['/route', this.SelectedRoute, this.ProjectLookup];\n        }\n        console.log('rlink: ', rLink);\n        return rLink;\n    }\n\n    // protected async handleStateChange(): Promise<void> {}\n}\n","<div class=\"breadcrumb-container\" *ngIf=\"!IsSmScreen\" fxLayout=\"row wrap\">\n    <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n        <ng-container *ngIf=\"Loading\">\n            <!-- <mat-icon skeleton-text [effect]=\"SkeletonEffect\">home</mat-icon> -->\n\n            <div skeleton-text [effect]=\"SkeletonEffect\">Enterprise Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"Enterprise && !Loading\">\n            <div class=\"crumb-name\" [routerLink]=\"['/enterprise']\">\n                {{ Enterprise?.Name }}\n            </div>\n\n            <button mat-icon-button [matMenuTriggerFor]=\"enterpriseMenu\">\n                <mat-icon>expand_more</mat-icon>\n            </button>\n\n            <mat-menu #enterpriseMenu=\"matMenu\" xPosition=\"before\">\n                <button\n                    mat-menu-item\n                    [routerLink]=\"['/enterprise']\"\n                    (click)=\"SetActiveEnterprise(ent.Lookup)\"\n                    *ngFor=\"let ent of Enterprises\"\n                    [matTooltip]=\"ent.Name\"\n                >\n                    <span>{{ ent.Name }}</span>\n                </button>\n            </mat-menu>\n        </ng-container>\n    </div>\n\n    <div\n        *ngIf=\"ProjectLookup && SelectedProject\"\n        fxLayout=\"row\"\n        fxLayoutAlign=\"center center\"\n    >\n        <span class=\"seperator\">/</span>\n\n        <ng-container *ngIf=\"Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Project Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!Loading\">\n            <div class=\"crumb-name\" [routerLink]=\"['/project', ProjectLookup]\">\n                {{ SelectedProject?.Project?.Name }}\n            </div>\n\n            <button mat-icon-button [matMenuTriggerFor]=\"projectMenu\">\n                <mat-icon>expand_more</mat-icon>\n            </button>\n\n            <mat-menu #projectMenu=\"matMenu\" xPosition=\"before\">\n                <ng-container *ngFor=\"let projectLookup of ProjectLookups\">\n                    <button\n                        mat-menu-item\n                        *ngIf=\"Projects[projectLookup]; let pro\"\n                        [matTooltip]=\"pro.Project?.Name\"\n                        [routerLink]=\"['/project', projectLookup]\"\n                    >\n                        <span>{{ pro.Project?.Name }}</span>\n                    </button>\n                </ng-container>\n            </mat-menu>\n        </ng-container>\n    </div>\n\n    <div *ngIf=\"SelectedRoute\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n        <span class=\"seperator\">/</span>\n\n        <ng-container *ngIf=\"Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Route Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!Loading\">\n            <div\n                class=\"crumb-name\"\n                [routerLink]=\"['/route', SelectedRoute, ProjectLookup]\"\n            >\n                {{ SelectedRoute }}\n            </div>\n\n            <button mat-icon-button [matMenuTriggerFor]=\"routeMenu\">\n                <mat-icon>expand_more</mat-icon>\n            </button>\n\n            <mat-menu #routeMenu=\"matMenu\" xPosition=\"before\">\n                <ng-container *ngFor=\"let appRoute of Routes\">\n                    <button\n                        mat-menu-item\n                        [routerLink]=\"['/route', appRoute, ProjectLookup]\"\n                        [matTooltip]=\"appRoute\"\n                    >\n                        <span *ngIf=\"appRoute\">{{ appRoute }}</span>\n                    </button>\n                </ng-container>\n            </mat-menu>\n        </ng-container>\n    </div>\n\n    <div\n        *ngIf=\"SelectedApplication && ApplicationLookup\"\n        fxLayout=\"row\"\n        fxLayoutAlign=\"center center\"\n    >\n        <span class=\"seperator\">/</span>\n\n        <ng-container *ngIf=\"Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Application Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!Loading\">\n            <div\n                class=\"crumb-name\"\n                [routerLink]=\"[\n                    '/application',\n                    ApplicationLookup,\n                    SelectedRoute,\n                    ProjectLookup\n                ]\"\n            >\n                {{ SelectedApplication?.Application?.Name }}\n            </div>\n\n            <button mat-icon-button [matMenuTriggerFor]=\"applicationMenu\">\n                <mat-icon>expand_more</mat-icon>\n            </button>\n\n            <mat-menu #applicationMenu=\"matMenu\" xPosition=\"before\">\n                <ng-container\n                    *ngFor=\"let appLookup of CurrentRouteApplicationLookups\"\n                >\n                    <button\n                        mat-menu-item\n                        [routerLink]=\"[\n                            '/application',\n                            appLookup,\n                            SelectedRoute,\n                            ProjectLookup\n                        ]\"\n                        *ngIf=\"\n                            RoutedApplications[SelectedRoute][appLookup];\n                            let app\n                        \"\n                        [matTooltip]=\"app.Application?.Name\"\n                    >\n                        <span>{{ app.Application?.Name }}</span>\n                    </button>\n                </ng-container>\n            </mat-menu>\n        </ng-container>\n    </div>\n</div>\n\n<!-- MOBILE VIEW -->\n\n<div\n    class=\"breadcrumb-container\"\n    *ngIf=\"IsSmScreen\"\n    fxLayout=\"row\"\n    fxLayoutAlign=\"start center\"\n>\n    <ng-container *ngIf=\"Loading\">\n        <mat-icon skeleton-text [effect]=\"SkeletonEffect\"\n            >chevron_left</mat-icon\n        >\n\n        <div skeleton-text [effect]=\"SkeletonEffect\">Current Path</div>\n\n        <mat-icon skeleton-text [effect]=\"SkeletonEffect\">expand_more</mat-icon>\n    </ng-container>\n\n    <ng-container *ngIf=\"!Loading\">\n        <button\n            *ngIf=\"ReturnRouterLink\"\n            mat-icon-button\n            [routerLink]=\"ReturnRouterLink\"\n        >\n            <mat-icon>chevron_left</mat-icon>\n        </button>\n        <ng-container [ngSwitch]=\"CurrentLevel\">\n            <ng-container *ngSwitchCase=\"'ent'\">\n                <div class=\"crumb-name\" [routerLink]=\"['/enterprise']\">\n                    <!-- <mat-icon>home</mat-icon> -->\n\n                    {{ Enterprise?.Name }}\n                </div>\n\n                <button mat-icon-button [matMenuTriggerFor]=\"enterpriseMenu\">\n                    <mat-icon>expand_more</mat-icon>\n                </button>\n\n                <mat-menu #enterpriseMenu=\"matMenu\" xPosition=\"before\">\n                    <button\n                        mat-menu-item\n                        [routerLink]=\"['/enterprise']\"\n                        (click)=\"SetActiveEnterprise(ent.Lookup)\"\n                        *ngFor=\"let ent of Enterprises\"\n                    >\n                        <span>{{ ent.Name }}</span>\n                    </button>\n                </mat-menu>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'project'\">\n                <div\n                    class=\"crumb-name\"\n                    [routerLink]=\"['/project', ProjectLookup]\"\n                >\n                    {{ SelectedProject?.Project?.Name }}\n                </div>\n\n                <button mat-icon-button [matMenuTriggerFor]=\"projectMenu\">\n                    <mat-icon>expand_more</mat-icon>\n                </button>\n\n                <mat-menu #projectMenu=\"matMenu\" xPosition=\"before\">\n                    <button\n                        mat-menu-item\n                        *ngFor=\"let projectLookup of ProjectLookups\"\n                        [routerLink]=\"['/project', projectLookup]\"\n                    >\n                        <span *ngIf=\"Projects[projectLookup]; let pro\">{{\n                            pro.Project?.Name\n                        }}</span>\n                    </button>\n                </mat-menu>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'route'\">\n                <div\n                    class=\"crumb-name\"\n                    [routerLink]=\"['/route', SelectedRoute, ProjectLookup]\"\n                >\n                    {{ SelectedRoute }}\n                </div>\n\n                <button mat-icon-button [matMenuTriggerFor]=\"routeMenu\">\n                    <mat-icon>expand_more</mat-icon>\n                </button>\n\n                <mat-menu #routeMenu=\"matMenu\" xPosition=\"before\">\n                    <button\n                        mat-menu-item\n                        *ngFor=\"let appRoute of Routes\"\n                        [routerLink]=\"['/route', appRoute, ProjectLookup]\"\n                    >\n                        <span *ngIf=\"appRoute\">{{ appRoute }}</span>\n                    </button>\n                </mat-menu>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'app'\">\n                <div\n                    class=\"crumb-name\"\n                    [routerLink]=\"[\n                        '/application',\n                        ApplicationLookup,\n                        SelectedRoute,\n                        ProjectLookup\n                    ]\"\n                >\n                    {{ SelectedApplication?.Application?.Name }}\n                </div>\n                <button mat-icon-button [matMenuTriggerFor]=\"applicationMenu\">\n                    <mat-icon>expand_more</mat-icon>\n                </button>\n\n                <mat-menu #applicationMenu=\"matMenu\" xPosition=\"before\">\n                    <button\n                        mat-menu-item\n                        *ngFor=\"let appLookup of CurrentRouteApplicationLookups\"\n                        [routerLink]=\"[\n                            '/application',\n                            appLookup,\n                            SelectedRoute,\n                            ProjectLookup\n                        ]\"\n                    >\n                        <span\n                            *ngIf=\"\n                                RoutedApplications[SelectedRoute][appLookup];\n                                let app\n                            \"\n                            >{{ app.Application?.Name }}</span\n                        >\n                    </button>\n                </mat-menu>\n            </ng-container>\n        </ng-container>\n    </ng-container>\n</div>\n"]}
@@ -4506,10 +4506,10 @@ class SourceControlDialogComponent {
4506
4506
  }
4507
4507
  }
4508
4508
  SourceControlDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: SourceControlDialogComponent, deps: [{ token: i2$2.MatDialogRef }, { token: EaCService }, { token: MAT_DIALOG_DATA }, { token: i3$2.MatSnackBar }], target: i0.ɵɵFactoryTarget.Component });
4509
- SourceControlDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: SourceControlDialogComponent, selector: "lcu-source-control-dialog", viewQueries: [{ propertyName: "DevopsSourceControl", first: true, predicate: DevopsSourceControlFormComponent, descendants: true }], ngImport: i0, template: "<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>Source Control</h2>\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n <ng-container *ngIf=\"!State?.GitHub?.HasConnection\">\n <lcu-git-auth></lcu-git-auth>\n </ng-container>\n\n <ng-conatiner *ngIf=\"State?.GitHub?.HasConnection\" fxLayout=\"column\">\n <div fxLayoutAlign=\"center center\">\n <lcu-devops-source-control-form\n [environment]=\"data.environment\"\n [environment-lookup]=\"data.environmentLookup\"\n [editing-source-control-lookup]=\"data.scLookup\"\n [loading]=\"State?.Loading\"\n (save-status-event)=\"HandleSaveStatusEvent($event)\"\n >\n </lcu-devops-source-control-form>\n </div>\n\n <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\">\n {{ ErrorMessage }}\n </mat-error>\n </ng-conatiner>\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 mat-raised-button\n color=\"warn\"\n (click)=\"DeleteSourceControl()\"\n matTooltip=\"Delete {{ data.scName }}\"\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=\"43%\"\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)=\"SaveSourceControl()\"\n [disabled]=\"\n !DevOpsSourceControlFormGroup?.valid ||\n !DevOpsSourceControlFormGroup?.dirty\n \"\n >\n <!-- <mat-icon>save</mat-icon> -->\n Save\n </button>\n </div>\n</mat-dialog-actions>\n", styles: [".dialog-header{width:100%}.action-button{margin:0 10px}\n"], components: [{ type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: GitAuthComponent, selector: "lcu-git-auth", inputs: ["size"] }, { type: DevopsSourceControlFormComponent, selector: "lcu-devops-source-control-form", inputs: ["editing-source-control-lookup", "environment", "environment-lookup", "loading"], outputs: ["save-status-event"] }], directives: [{ type: i7$3.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i2$2.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i2$2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7$3.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i4.MatError, selector: "mat-error", inputs: ["id"] }, { type: i2$2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i7$2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i7$3.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }] });
4509
+ SourceControlDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: SourceControlDialogComponent, selector: "lcu-source-control-dialog", viewQueries: [{ propertyName: "DevopsSourceControl", first: true, predicate: DevopsSourceControlFormComponent, descendants: true }], ngImport: i0, template: "<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>Source Control</h2>\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n <ng-container *ngIf=\"!State?.GitHub?.HasConnection\">\n <lcu-git-auth></lcu-git-auth>\n </ng-container>\n\n <ng-container *ngIf=\"State?.GitHub?.HasConnection\" fxLayout=\"column\">\n <div fxLayoutAlign=\"center center\">\n <lcu-devops-source-control-form\n [environment]=\"data.environment\"\n [environment-lookup]=\"data.environmentLookup\"\n [editing-source-control-lookup]=\"data.scLookup\"\n [loading]=\"State?.Loading\"\n (save-status-event)=\"HandleSaveStatusEvent($event)\"\n >\n </lcu-devops-source-control-form>\n </div>\n\n <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\">\n {{ ErrorMessage }}\n </mat-error>\n </ng-container>\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 mat-raised-button\n color=\"warn\"\n (click)=\"DeleteSourceControl()\"\n matTooltip=\"Delete {{ data.scName }}\"\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=\"43%\"\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)=\"SaveSourceControl()\"\n [disabled]=\"\n !DevOpsSourceControlFormGroup?.valid ||\n !DevOpsSourceControlFormGroup?.dirty\n \"\n >\n <!-- <mat-icon>save</mat-icon> -->\n Save\n </button>\n </div>\n</mat-dialog-actions>\n", styles: [".dialog-header{width:100%}.action-button{margin:0 10px}\n"], components: [{ type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: GitAuthComponent, selector: "lcu-git-auth", inputs: ["size"] }, { type: DevopsSourceControlFormComponent, selector: "lcu-devops-source-control-form", inputs: ["editing-source-control-lookup", "environment", "environment-lookup", "loading"], outputs: ["save-status-event"] }], directives: [{ type: i7$3.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i2$2.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i2$2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7$3.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i4.MatError, selector: "mat-error", inputs: ["id"] }, { type: i2$2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i7$2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i7$3.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }] });
4510
4510
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: SourceControlDialogComponent, decorators: [{
4511
4511
  type: Component,
4512
- args: [{ selector: 'lcu-source-control-dialog', template: "<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>Source Control</h2>\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n <ng-container *ngIf=\"!State?.GitHub?.HasConnection\">\n <lcu-git-auth></lcu-git-auth>\n </ng-container>\n\n <ng-conatiner *ngIf=\"State?.GitHub?.HasConnection\" fxLayout=\"column\">\n <div fxLayoutAlign=\"center center\">\n <lcu-devops-source-control-form\n [environment]=\"data.environment\"\n [environment-lookup]=\"data.environmentLookup\"\n [editing-source-control-lookup]=\"data.scLookup\"\n [loading]=\"State?.Loading\"\n (save-status-event)=\"HandleSaveStatusEvent($event)\"\n >\n </lcu-devops-source-control-form>\n </div>\n\n <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\">\n {{ ErrorMessage }}\n </mat-error>\n </ng-conatiner>\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 mat-raised-button\n color=\"warn\"\n (click)=\"DeleteSourceControl()\"\n matTooltip=\"Delete {{ data.scName }}\"\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=\"43%\"\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)=\"SaveSourceControl()\"\n [disabled]=\"\n !DevOpsSourceControlFormGroup?.valid ||\n !DevOpsSourceControlFormGroup?.dirty\n \"\n >\n <!-- <mat-icon>save</mat-icon> -->\n Save\n </button>\n </div>\n</mat-dialog-actions>\n", styles: [".dialog-header{width:100%}.action-button{margin:0 10px}\n"] }]
4512
+ args: [{ selector: 'lcu-source-control-dialog', template: "<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>Source Control</h2>\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n <ng-container *ngIf=\"!State?.GitHub?.HasConnection\">\n <lcu-git-auth></lcu-git-auth>\n </ng-container>\n\n <ng-container *ngIf=\"State?.GitHub?.HasConnection\" fxLayout=\"column\">\n <div fxLayoutAlign=\"center center\">\n <lcu-devops-source-control-form\n [environment]=\"data.environment\"\n [environment-lookup]=\"data.environmentLookup\"\n [editing-source-control-lookup]=\"data.scLookup\"\n [loading]=\"State?.Loading\"\n (save-status-event)=\"HandleSaveStatusEvent($event)\"\n >\n </lcu-devops-source-control-form>\n </div>\n\n <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\">\n {{ ErrorMessage }}\n </mat-error>\n </ng-container>\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 mat-raised-button\n color=\"warn\"\n (click)=\"DeleteSourceControl()\"\n matTooltip=\"Delete {{ data.scName }}\"\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=\"43%\"\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)=\"SaveSourceControl()\"\n [disabled]=\"\n !DevOpsSourceControlFormGroup?.valid ||\n !DevOpsSourceControlFormGroup?.dirty\n \"\n >\n <!-- <mat-icon>save</mat-icon> -->\n Save\n </button>\n </div>\n</mat-dialog-actions>\n", styles: [".dialog-header{width:100%}.action-button{margin:0 10px}\n"] }]
4513
4513
  }], ctorParameters: function () {
4514
4514
  return [{ type: i2$2.MatDialogRef }, { type: EaCService }, { type: undefined, decorators: [{
4515
4515
  type: Inject,
@@ -5170,11 +5170,15 @@ class ProcessorDetailsFormComponent {
5170
5170
  }
5171
5171
  ProcessorTypeChanged(event) {
5172
5172
  this.ProcessorType = event.value;
5173
+ this.LCUType = null;
5173
5174
  this.setupProcessorTypeSubForm();
5175
+ // console.log("proc type changed: ", this.ProcessorDetailsFormGroup.controls)
5174
5176
  }
5175
5177
  LCUTypeChanged(event) {
5176
5178
  this.LCUType = event.value;
5179
+ // console.log("lcu type changed: ", event.value)
5177
5180
  this.setupLcuTypeSubForm();
5181
+ // console.log("lcu type changed: ", this.ProcessorDetailsFormGroup.controls)
5178
5182
  }
5179
5183
  //HELPERS
5180
5184
  cleanupLcuTypeSubForm() {
@@ -5190,6 +5194,7 @@ class ProcessorDetailsFormComponent {
5190
5194
  this.ProcessorDetailsFormGroup.removeControl('package');
5191
5195
  this.ProcessorDetailsFormGroup.removeControl('version');
5192
5196
  this.ProcessorDetailsFormGroup.removeControl('zipFile');
5197
+ // console.log("proc group: ", this.ProcessorDetailsFormGroup.controls);
5193
5198
  }
5194
5199
  cleanupProcessorTypeSubForm() {
5195
5200
  this.ProcessorDetailsFormGroup.removeControl('defaultFile');
@@ -5892,9 +5897,9 @@ class BreadcrumbComponent {
5892
5897
  if (this.RoutedApplications &&
5893
5898
  ((_a = Object.keys(this.RoutedApplications)) === null || _a === void 0 ? void 0 : _a.length) !== 0) {
5894
5899
  this.Routes = Object.keys(this.RoutedApplications || {});
5895
- console.log('routed apps: ', this.RoutedApplications);
5900
+ // console.log('routed apps: ', this.RoutedApplications);
5896
5901
  if (this.SelectedRoute) {
5897
- console.log('selected route: ', this.SelectedRoute);
5902
+ // console.log('selected route: ', this.SelectedRoute);
5898
5903
  this.CurrentRouteApplicationLookups =
5899
5904
  Object.keys(this.RoutedApplications[this.SelectedRoute]) ||
5900
5905
  [];