@lowcodeunit/applications-flow-common 1.39.39-hardening-bugs → 1.39.40-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.
@@ -107,14 +107,14 @@ export class ApplicationsCardComponent {
107
107
  window.location.href = path;
108
108
  }
109
109
  BuildProjectTree() {
110
- console.log('calling build project tree');
110
+ // console.log('calling build project tree');
111
111
  let tempTreeData = [];
112
112
  let tempApps = this.CurrentRouteApplicationLookups;
113
113
  if (tempApps) {
114
114
  let tempRouteChildren = [];
115
115
  tempApps.forEach((appLookup) => {
116
116
  let tempApp = this.RoutedApplications[this.AppRoute][appLookup];
117
- console.log('tempApp: ', tempApp);
117
+ // console.log('tempApp: ', tempApp);
118
118
  let appPath = tempApp.LookupConfig?.PathRegex.substring(0, tempApp.LookupConfig?.PathRegex.length - 2);
119
119
  let tempAppNode = {
120
120
  lookup: appLookup,
@@ -217,4 +217,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
217
217
  type: Input,
218
218
  args: ['project-lookup']
219
219
  }] } });
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"applications-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/applications-card/applications-card.component.ts","../../../../../../projects/common/src/lib/elements/applications-card/applications-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FlatTreeControl } from '@angular/cdk/tree';\nimport { Component, Input, OnInit } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport {\n    MatTreeFlatDataSource,\n    MatTreeFlattener,\n} from '@angular/material/tree';\nimport { EaCApplicationAsCode, EaCProjectAsCode } from '@semanticjs/common';\nimport { NewApplicationDialogComponent } from '../../dialogs/new-application-dialog/new-application-dialog.component';\nimport { FlatNode, TreeNode } from '../../models/tree-node.model';\n\n@Component({\n    selector: 'lcu-applications-card',\n    templateUrl: './applications-card.component.html',\n    styleUrls: ['./applications-card.component.scss'],\n})\nexport class ApplicationsCardComponent implements OnInit {\n    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    @Input('applications-bank')\n    public ApplicationsBank: Array<EaCApplicationAsCode>;\n\n    @Input('app-route')\n    public AppRoute: string;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Input('project')\n    public Project: EaCProjectAsCode;\n\n    @Input('project-lookup')\n    public ProjectLookup: string;\n\n    private transformer = (node: TreeNode, level: number) => {\n        return {\n            expandable: !!node.children && node.children.length > 0,\n            name: node.name,\n            level: level,\n            routerLink: node.routerLink,\n            url: node.url,\n            lookup: node.lookup,\n            description: node.description,\n        };\n    };\n\n    protected get Applications(): {\n        [lookup: string]: EaCApplicationAsCode;\n    } {\n        const apps: { [lookup: string]: EaCApplicationAsCode } = {};\n\n        this.Project?.ApplicationLookups?.forEach((appLookup: string) => {\n            apps[appLookup] = this.ApplicationsBank[appLookup];\n        });\n        return apps;\n    }\n\n    protected get ApplicationRoutes(): Array<string> {\n        return Object.keys(this.RoutedApplications || {});\n    }\n\n    public get CurrentRouteApplicationLookups(): Array<string> {\n        return Object.keys(this.RoutedApplications[this.AppRoute] || {});\n    }\n\n    protected get RoutedApplications(): {\n        [route: string]: { [lookup: string]: EaCApplicationAsCode };\n    } {\n        const appLookups = Object.keys(this.Applications);\n\n        const apps = appLookups.map(\n            (appLookup) => this.Applications[appLookup]\n        );\n\n        let appRoutes =\n            apps.map((app) => {\n                // console.log(\"App from projects: \", app);\n                return app?.LookupConfig?.PathRegex.replace('.*', '');\n            }) || [];\n\n        appRoutes = appRoutes.filter((ar) => ar != null);\n\n        let routeBases: string[] = [];\n\n        appRoutes.forEach((appRoute) => {\n            const appRouteParts = appRoute.split('/');\n\n            const appRouteBase = `/${appRouteParts[1]}`;\n\n            if (routeBases.indexOf(appRouteBase) < 0) {\n                routeBases.push(appRouteBase);\n            }\n        });\n\n        let workingAppLookups = [...(appLookups || [])];\n\n        routeBases = routeBases.sort((a, b) => b.localeCompare(a));\n\n        const routeSet =\n            routeBases.reduce((prevRouteMap, currentRouteBase) => {\n                const routeMap = {\n                    ...prevRouteMap,\n                };\n\n                const filteredAppLookups = workingAppLookups.filter((wal) => {\n                    const wa = this.Applications[wal];\n\n                    return wa?.LookupConfig?.PathRegex.startsWith(\n                        currentRouteBase\n                    );\n                });\n\n                routeMap[currentRouteBase] =\n                    filteredAppLookups.reduce((prevAppMap, appLookup) => {\n                        const appMap: any = {\n                            ...prevAppMap,\n                        };\n\n                        appMap[appLookup] = this.Applications[appLookup];\n\n                        return appMap;\n                    }, {}) || {};\n\n                workingAppLookups = workingAppLookups.filter((wa) => {\n                    return filteredAppLookups.indexOf(wa) < 0;\n                });\n\n                return routeMap;\n            }, {}) || {};\n\n        let routeSetKeys = Object.keys(routeSet);\n\n        routeSetKeys = routeSetKeys.sort((a, b) => a.localeCompare(b));\n\n        const routeSetResult = {};\n\n        routeSetKeys.forEach((rsk) => (routeSetResult[rsk] = routeSet[rsk]));\n\n        // console.log(\"App Routes: \",routeSetResult)\n\n        return routeSetResult;\n    }\n\n    treeControl = new FlatTreeControl<FlatNode>(\n        (node: any) => node.level,\n        (node: any) => node.expandable\n    );\n\n    treeFlattener = new MatTreeFlattener(\n        this.transformer,\n        (node) => node.level,\n        (node) => node.expandable,\n        (node) => node.children\n    );\n\n    public DataSource = new MatTreeFlatDataSource(\n        this.treeControl,\n        this.treeFlattener\n    );\n\n    // public RoutedApplications: any;\n\n    constructor(protected dialog: MatDialog) {}\n\n    public HasChild = (_: number, node: FlatNode) => node.expandable;\n\n    public ngOnInit(): void {}\n\n    public ngOnChanges() {\n        // console.log('app bank: ', this.ApplicationsBank);\n        if (this.ApplicationsBank) {\n            let temp = this.BuildProjectTree();\n            // console.log('to string: ', JSON.stringify(temp));\n\n            if (JSON.stringify(this.DataSource.data) !== JSON.stringify(temp)) {\n                // console.log('Its different')\n                this.DataSource.data = temp;\n            }\n        }\n    }\n\n    public RouteToPath(path: string): void {\n        window.location.href = path;\n    }\n\n    public BuildProjectTree(): Array<TreeNode> {\n        console.log('calling build project tree');\n        let tempTreeData: Array<TreeNode> = [];\n\n        let tempApps = this.CurrentRouteApplicationLookups;\n        if (tempApps) {\n            let tempRouteChildren: Array<TreeNode> = [];\n            tempApps.forEach((appLookup: string) => {\n                let tempApp = this.RoutedApplications[this.AppRoute][appLookup];\n                console.log('tempApp: ', tempApp);\n                let appPath = tempApp.LookupConfig?.PathRegex.substring(\n                    0,\n                    tempApp.LookupConfig?.PathRegex.length - 2\n                );\n                let tempAppNode: TreeNode = {\n                    lookup: appLookup,\n                    name: tempApp.Application.Name,\n                    url: 'https://' + this.Project?.PrimaryHost + appPath,\n                    description: tempApp.Application.Description,\n                    routerLink: [\n                        '/application',\n                        appLookup,\n                        this.AppRoute,\n                        this.ProjectLookup,\n                    ],\n                };\n                tempTreeData.push(tempAppNode);\n            });\n        }\n\n        // console.log('THE TREE: ', tempTreeData);\n        return tempTreeData;\n\n        // return tempTreeData;\n    }\n\n    public BuildRouteTree() {\n        console.log('called route tree');\n        let tempTreeData: Array<TreeNode> = [];\n\n        let tempRoutes = this.ApplicationRoutes;\n        if (tempRoutes) {\n            // let tempProjChildren: Array<TreeNode> = [];\n            tempRoutes.forEach((appRoute: string) => {\n                this.AppRoute = appRoute;\n\n                let tempRouteNode: TreeNode = {\n                    name: this.AppRoute,\n                    url: 'https://' + this.Project?.PrimaryHost + this.AppRoute,\n                    routerLink: ['/route', this.AppRoute, this.ProjectLookup],\n                };\n\n                let tempApps = this.CurrentRouteApplicationLookups;\n                if (tempApps) {\n                    let tempRouteChildren: Array<TreeNode> = [];\n                    tempApps.forEach((appLookup: string) => {\n                        let tempApp =\n                            this.RoutedApplications[this.AppRoute][appLookup];\n                        let tempAppNode: TreeNode = {\n                            lookup: appLookup,\n                            name: tempApp.Application.Name,\n                            url:\n                                'https://' +\n                                this.Project?.PrimaryHost +\n                                this.AppRoute,\n                            description: tempApp.Application.Description,\n                            routerLink: [\n                                '/application',\n                                appLookup,\n                                this.AppRoute,\n                                this.ProjectLookup,\n                            ],\n                        };\n                        tempRouteChildren.push(tempAppNode);\n                    });\n                    tempRouteNode.children = tempRouteChildren;\n                }\n                tempTreeData.push(tempRouteNode);\n            });\n        }\n        return tempTreeData;\n    }\n\n    public HandleRoute(route: string) {\n        console.log('route: ', route);\n    }\n\n    public OpenNewAppDialog(event: any) {\n        const dialogRef = this.dialog.open(NewApplicationDialogComponent, {\n            width: '600px',\n            data: {\n                projectLookup: this.ProjectLookup,\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","<!-- TREE -->\n<lcu-slotted-card-lg\n    *ngIf=\"ApplicationsBank\"\n    class=\"fit-content\"\n    card-title=\"Application\"\n    [loading]=\"Loading\"\n    [main-slot-description]=\"\n        CurrentRouteApplicationLookups?.length + ' route(s) configured'\n    \"\n    (main-action-clicked)=\"OpenNewAppDialog($event)\"\n>\n    <!-- <div> -->\n    <ng-container *ngIf=\"DataSource\">\n        <mat-tree [dataSource]=\"DataSource\" [treeControl]=\"treeControl\">\n            <mat-tree-node *matTreeNodeDef=\"let node\" matTreeNodePadding>\n                <a\n                    *ngIf=\"node.routerLink\"\n                    class=\"slot-header-anchor\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </a>\n                <div\n                    *ngIf=\"!node.routerLink\"\n                    class=\"tree-header\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </div>\n                <div\n                    class=\"slot-actions-container\"\n                    fxLayout=\"row\"\n                    fxLayoutAlign=\"space-around center\"\n                >\n                    <a\n                        *ngIf=\"node.routerLink\"\n                        class=\"slot-action-anchor\"\n                        [routerLink]=\"node.routerLink\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Edit {{ node.name }}\"\n                            >edit</mat-icon\n                        >\n                    </a>\n                    <a\n                        class=\"slot-action-anchor\"\n                        [href]=\"node.url\"\n                        target=\"_blank\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Launch {{ node.name }}\"\n                            >launch</mat-icon\n                        >\n                    </a>\n                </div>\n                <!-- <button mat-icon-button></button> -->\n            </mat-tree-node>\n            <mat-tree-node\n                *matTreeNodeDef=\"let node; when: HasChild\"\n                matTreeNodePadding\n            >\n                <button\n                    mat-icon-button\n                    matTreeNodeToggle\n                    [attr.aria-label]=\"'Toggle ' + node.name\"\n                >\n                    <mat-icon class=\"mat-icon-rtl-mirror\">\n                        {{\n                            treeControl.isExpanded(node)\n                                ? \"expand_more\"\n                                : \"chevron_right\"\n                        }}\n                    </mat-icon>\n                </button>\n                <a\n                    *ngIf=\"node.routerLink\"\n                    class=\"slot-header-anchor\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </a>\n                <div\n                    *ngIf=\"!node.routerLink\"\n                    class=\"tree-header\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </div>\n                <div\n                    class=\"slot-actions-container\"\n                    fxLayout=\"row\"\n                    fxLayoutAlign=\"space-around center\"\n                >\n                    <a\n                        *ngIf=\"node.routerLink\"\n                        class=\"slot-action-anchor\"\n                        [routerLink]=\"node.routerLink\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Edit {{ node.name }}\"\n                            >edit</mat-icon\n                        >\n                    </a>\n                    <a\n                        class=\"slot-action-anchor\"\n                        [href]=\"node.url\"\n                        target=\"_blank\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Launch {{ node.name }}\"\n                            >launch</mat-icon\n                        >\n                    </a>\n                </div>\n            </mat-tree-node>\n        </mat-tree>\n    </ng-container>\n</lcu-slotted-card-lg>\n"]}
220
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"applications-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/applications-card/applications-card.component.ts","../../../../../../projects/common/src/lib/elements/applications-card/applications-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FlatTreeControl } from '@angular/cdk/tree';\nimport { Component, Input, OnInit } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport {\n    MatTreeFlatDataSource,\n    MatTreeFlattener,\n} from '@angular/material/tree';\nimport { EaCApplicationAsCode, EaCProjectAsCode } from '@semanticjs/common';\nimport { NewApplicationDialogComponent } from '../../dialogs/new-application-dialog/new-application-dialog.component';\nimport { FlatNode, TreeNode } from '../../models/tree-node.model';\n\n@Component({\n    selector: 'lcu-applications-card',\n    templateUrl: './applications-card.component.html',\n    styleUrls: ['./applications-card.component.scss'],\n})\nexport class ApplicationsCardComponent implements OnInit {\n    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    @Input('applications-bank')\n    public ApplicationsBank: Array<EaCApplicationAsCode>;\n\n    @Input('app-route')\n    public AppRoute: string;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Input('project')\n    public Project: EaCProjectAsCode;\n\n    @Input('project-lookup')\n    public ProjectLookup: string;\n\n    private transformer = (node: TreeNode, level: number) => {\n        return {\n            expandable: !!node.children && node.children.length > 0,\n            name: node.name,\n            level: level,\n            routerLink: node.routerLink,\n            url: node.url,\n            lookup: node.lookup,\n            description: node.description,\n        };\n    };\n\n    protected get Applications(): {\n        [lookup: string]: EaCApplicationAsCode;\n    } {\n        const apps: { [lookup: string]: EaCApplicationAsCode } = {};\n\n        this.Project?.ApplicationLookups?.forEach((appLookup: string) => {\n            apps[appLookup] = this.ApplicationsBank[appLookup];\n        });\n        return apps;\n    }\n\n    protected get ApplicationRoutes(): Array<string> {\n        return Object.keys(this.RoutedApplications || {});\n    }\n\n    public get CurrentRouteApplicationLookups(): Array<string> {\n        return Object.keys(this.RoutedApplications[this.AppRoute] || {});\n    }\n\n    protected get RoutedApplications(): {\n        [route: string]: { [lookup: string]: EaCApplicationAsCode };\n    } {\n        const appLookups = Object.keys(this.Applications);\n\n        const apps = appLookups.map(\n            (appLookup) => this.Applications[appLookup]\n        );\n\n        let appRoutes =\n            apps.map((app) => {\n                // console.log(\"App from projects: \", app);\n                return app?.LookupConfig?.PathRegex.replace('.*', '');\n            }) || [];\n\n        appRoutes = appRoutes.filter((ar) => ar != null);\n\n        let routeBases: string[] = [];\n\n        appRoutes.forEach((appRoute) => {\n            const appRouteParts = appRoute.split('/');\n\n            const appRouteBase = `/${appRouteParts[1]}`;\n\n            if (routeBases.indexOf(appRouteBase) < 0) {\n                routeBases.push(appRouteBase);\n            }\n        });\n\n        let workingAppLookups = [...(appLookups || [])];\n\n        routeBases = routeBases.sort((a, b) => b.localeCompare(a));\n\n        const routeSet =\n            routeBases.reduce((prevRouteMap, currentRouteBase) => {\n                const routeMap = {\n                    ...prevRouteMap,\n                };\n\n                const filteredAppLookups = workingAppLookups.filter((wal) => {\n                    const wa = this.Applications[wal];\n\n                    return wa?.LookupConfig?.PathRegex.startsWith(\n                        currentRouteBase\n                    );\n                });\n\n                routeMap[currentRouteBase] =\n                    filteredAppLookups.reduce((prevAppMap, appLookup) => {\n                        const appMap: any = {\n                            ...prevAppMap,\n                        };\n\n                        appMap[appLookup] = this.Applications[appLookup];\n\n                        return appMap;\n                    }, {}) || {};\n\n                workingAppLookups = workingAppLookups.filter((wa) => {\n                    return filteredAppLookups.indexOf(wa) < 0;\n                });\n\n                return routeMap;\n            }, {}) || {};\n\n        let routeSetKeys = Object.keys(routeSet);\n\n        routeSetKeys = routeSetKeys.sort((a, b) => a.localeCompare(b));\n\n        const routeSetResult = {};\n\n        routeSetKeys.forEach((rsk) => (routeSetResult[rsk] = routeSet[rsk]));\n\n        // console.log(\"App Routes: \",routeSetResult)\n\n        return routeSetResult;\n    }\n\n    treeControl = new FlatTreeControl<FlatNode>(\n        (node: any) => node.level,\n        (node: any) => node.expandable\n    );\n\n    treeFlattener = new MatTreeFlattener(\n        this.transformer,\n        (node) => node.level,\n        (node) => node.expandable,\n        (node) => node.children\n    );\n\n    public DataSource = new MatTreeFlatDataSource(\n        this.treeControl,\n        this.treeFlattener\n    );\n\n    // public RoutedApplications: any;\n\n    constructor(protected dialog: MatDialog) {}\n\n    public HasChild = (_: number, node: FlatNode) => node.expandable;\n\n    public ngOnInit(): void {}\n\n    public ngOnChanges() {\n        // console.log('app bank: ', this.ApplicationsBank);\n        if (this.ApplicationsBank) {\n            let temp = this.BuildProjectTree();\n            // console.log('to string: ', JSON.stringify(temp));\n\n            if (JSON.stringify(this.DataSource.data) !== JSON.stringify(temp)) {\n                // console.log('Its different')\n                this.DataSource.data = temp;\n            }\n        }\n    }\n\n    public RouteToPath(path: string): void {\n        window.location.href = path;\n    }\n\n    public BuildProjectTree(): Array<TreeNode> {\n        // console.log('calling build project tree');\n        let tempTreeData: Array<TreeNode> = [];\n\n        let tempApps = this.CurrentRouteApplicationLookups;\n        if (tempApps) {\n            let tempRouteChildren: Array<TreeNode> = [];\n            tempApps.forEach((appLookup: string) => {\n                let tempApp = this.RoutedApplications[this.AppRoute][appLookup];\n                // console.log('tempApp: ', tempApp);\n                let appPath = tempApp.LookupConfig?.PathRegex.substring(\n                    0,\n                    tempApp.LookupConfig?.PathRegex.length - 2\n                );\n                let tempAppNode: TreeNode = {\n                    lookup: appLookup,\n                    name: tempApp.Application.Name,\n                    url: 'https://' + this.Project?.PrimaryHost + appPath,\n                    description: tempApp.Application.Description,\n                    routerLink: [\n                        '/application',\n                        appLookup,\n                        this.AppRoute,\n                        this.ProjectLookup,\n                    ],\n                };\n                tempTreeData.push(tempAppNode);\n            });\n        }\n\n        // console.log('THE TREE: ', tempTreeData);\n        return tempTreeData;\n\n        // return tempTreeData;\n    }\n\n    public BuildRouteTree() {\n        console.log('called route tree');\n        let tempTreeData: Array<TreeNode> = [];\n\n        let tempRoutes = this.ApplicationRoutes;\n        if (tempRoutes) {\n            // let tempProjChildren: Array<TreeNode> = [];\n            tempRoutes.forEach((appRoute: string) => {\n                this.AppRoute = appRoute;\n\n                let tempRouteNode: TreeNode = {\n                    name: this.AppRoute,\n                    url: 'https://' + this.Project?.PrimaryHost + this.AppRoute,\n                    routerLink: ['/route', this.AppRoute, this.ProjectLookup],\n                };\n\n                let tempApps = this.CurrentRouteApplicationLookups;\n                if (tempApps) {\n                    let tempRouteChildren: Array<TreeNode> = [];\n                    tempApps.forEach((appLookup: string) => {\n                        let tempApp =\n                            this.RoutedApplications[this.AppRoute][appLookup];\n                        let tempAppNode: TreeNode = {\n                            lookup: appLookup,\n                            name: tempApp.Application.Name,\n                            url:\n                                'https://' +\n                                this.Project?.PrimaryHost +\n                                this.AppRoute,\n                            description: tempApp.Application.Description,\n                            routerLink: [\n                                '/application',\n                                appLookup,\n                                this.AppRoute,\n                                this.ProjectLookup,\n                            ],\n                        };\n                        tempRouteChildren.push(tempAppNode);\n                    });\n                    tempRouteNode.children = tempRouteChildren;\n                }\n                tempTreeData.push(tempRouteNode);\n            });\n        }\n        return tempTreeData;\n    }\n\n    public HandleRoute(route: string) {\n        console.log('route: ', route);\n    }\n\n    public OpenNewAppDialog(event: any) {\n        const dialogRef = this.dialog.open(NewApplicationDialogComponent, {\n            width: '600px',\n            data: {\n                projectLookup: this.ProjectLookup,\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","<!-- TREE -->\n<lcu-slotted-card-lg\n    *ngIf=\"ApplicationsBank\"\n    class=\"fit-content\"\n    card-title=\"Application\"\n    [loading]=\"Loading\"\n    [main-slot-description]=\"\n        CurrentRouteApplicationLookups?.length + ' route(s) configured'\n    \"\n    (main-action-clicked)=\"OpenNewAppDialog($event)\"\n>\n    <!-- <div> -->\n    <ng-container *ngIf=\"DataSource\">\n        <mat-tree [dataSource]=\"DataSource\" [treeControl]=\"treeControl\">\n            <mat-tree-node *matTreeNodeDef=\"let node\" matTreeNodePadding>\n                <a\n                    *ngIf=\"node.routerLink\"\n                    class=\"slot-header-anchor\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </a>\n                <div\n                    *ngIf=\"!node.routerLink\"\n                    class=\"tree-header\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </div>\n                <div\n                    class=\"slot-actions-container\"\n                    fxLayout=\"row\"\n                    fxLayoutAlign=\"space-around center\"\n                >\n                    <a\n                        *ngIf=\"node.routerLink\"\n                        class=\"slot-action-anchor\"\n                        [routerLink]=\"node.routerLink\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Edit {{ node.name }}\"\n                            >edit</mat-icon\n                        >\n                    </a>\n                    <a\n                        class=\"slot-action-anchor\"\n                        [href]=\"node.url\"\n                        target=\"_blank\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Launch {{ node.name }}\"\n                            >launch</mat-icon\n                        >\n                    </a>\n                </div>\n                <!-- <button mat-icon-button></button> -->\n            </mat-tree-node>\n            <mat-tree-node\n                *matTreeNodeDef=\"let node; when: HasChild\"\n                matTreeNodePadding\n            >\n                <button\n                    mat-icon-button\n                    matTreeNodeToggle\n                    [attr.aria-label]=\"'Toggle ' + node.name\"\n                >\n                    <mat-icon class=\"mat-icon-rtl-mirror\">\n                        {{\n                            treeControl.isExpanded(node)\n                                ? \"expand_more\"\n                                : \"chevron_right\"\n                        }}\n                    </mat-icon>\n                </button>\n                <a\n                    *ngIf=\"node.routerLink\"\n                    class=\"slot-header-anchor\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </a>\n                <div\n                    *ngIf=\"!node.routerLink\"\n                    class=\"tree-header\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </div>\n                <div\n                    class=\"slot-actions-container\"\n                    fxLayout=\"row\"\n                    fxLayoutAlign=\"space-around center\"\n                >\n                    <a\n                        *ngIf=\"node.routerLink\"\n                        class=\"slot-action-anchor\"\n                        [routerLink]=\"node.routerLink\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Edit {{ node.name }}\"\n                            >edit</mat-icon\n                        >\n                    </a>\n                    <a\n                        class=\"slot-action-anchor\"\n                        [href]=\"node.url\"\n                        target=\"_blank\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Launch {{ node.name }}\"\n                            >launch</mat-icon\n                        >\n                    </a>\n                </div>\n            </mat-tree-node>\n        </mat-tree>\n    </ng-container>\n</lcu-slotted-card-lg>\n"]}
@@ -26,7 +26,7 @@ export class BreadcrumbComponent {
26
26
  else {
27
27
  this.IsSmScreen = false;
28
28
  }
29
- console.log('small: ', this.IsSmScreen);
29
+ // console.log('small: ', this.IsSmScreen);
30
30
  if (this.IsSmScreen) {
31
31
  this.CurrentLevel = this.determineCurrentLevel();
32
32
  this.ReturnRouterLink = this.determineReturnRouterLink();
@@ -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"]}
@@ -103,7 +103,7 @@ export class ProjectCardComponent {
103
103
  window.location.href = path;
104
104
  }
105
105
  BuildProjectTree() {
106
- console.log('calling build project tree');
106
+ // console.log('calling build project tree');
107
107
  let tempTreeData = [];
108
108
  this.ProjectLookups?.forEach((pLookup) => {
109
109
  let tempProj = this.Projects[pLookup];
@@ -229,4 +229,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
229
229
  type: Input,
230
230
  args: ['project-lookup']
231
231
  }] } });
232
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"project-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/project-card/project-card.component.ts","../../../../../../projects/common/src/lib/elements/project-card/project-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FlatTreeControl } from '@angular/cdk/tree';\nimport { Component, Input, OnInit } from '@angular/core';\nimport {\n    MatTreeFlatDataSource,\n    MatTreeFlattener,\n} from '@angular/material/tree';\nimport { EaCApplicationAsCode, EaCProjectAsCode } from '@semanticjs/common';\nimport { FlatNode, TreeNode } from '../../models/tree-node.model';\n\n@Component({\n    selector: 'lcu-project-card',\n    templateUrl: './project-card.component.html',\n    styleUrls: ['./project-card.component.scss'],\n})\nexport class ProjectCardComponent implements OnInit {\n    @Input('applications-bank')\n    public ApplicationsBank: Array<EaCApplicationAsCode>;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Input('project-lookups')\n    public ProjectLookups: Array<string>;\n\n    @Input('projects')\n    public Projects: Array<EaCProjectAsCode>;\n\n    private transformer = (node: TreeNode, level: number) => {\n        return {\n            expandable: !!node.children && node.children.length > 0,\n            name: node.name,\n            level: level,\n            routerLink: node.routerLink,\n            url: node.url,\n            lookup: node.lookup,\n            description: node.description,\n        };\n    };\n\n    protected get Applications(): {\n        [lookup: string]: EaCApplicationAsCode;\n    } {\n        const apps: { [lookup: string]: EaCApplicationAsCode } = {};\n\n        this.Project?.ApplicationLookups?.forEach((appLookup: string) => {\n            apps[appLookup] = this.ApplicationsBank[appLookup];\n        });\n        return apps;\n    }\n\n    protected get ApplicationRoutes(): Array<string> {\n        return Object.keys(this.RoutedApplications || {});\n    }\n\n    protected get CurrentRouteApplicationLookups(): Array<string> {\n        return Object.keys(this.RoutedApplications[this.AppRoute] || {});\n    }\n\n    protected get RoutedApplications(): {\n        [route: string]: { [lookup: string]: EaCApplicationAsCode };\n    } {\n        const appLookups = Object.keys(this.Applications);\n\n        const apps = appLookups.map(\n            (appLookup) => this.Applications[appLookup]\n        );\n\n        let appRoutes =\n            apps.map((app) => {\n                // console.log(\"App from projects: \", app);\n                return app?.LookupConfig?.PathRegex.replace('.*', '');\n            }) || [];\n\n        appRoutes = appRoutes.filter((ar) => ar != null);\n\n        let routeBases: string[] = [];\n\n        appRoutes.forEach((appRoute) => {\n            const appRouteParts = appRoute.split('/');\n\n            const appRouteBase = `/${appRouteParts[1]}`;\n\n            if (routeBases.indexOf(appRouteBase) < 0) {\n                routeBases.push(appRouteBase);\n            }\n        });\n\n        let workingAppLookups = [...(appLookups || [])];\n\n        routeBases = routeBases.sort((a, b) => b.localeCompare(a));\n\n        const routeSet =\n            routeBases.reduce((prevRouteMap, currentRouteBase) => {\n                const routeMap = {\n                    ...prevRouteMap,\n                };\n\n                const filteredAppLookups = workingAppLookups.filter((wal) => {\n                    const wa = this.Applications[wal];\n\n                    return wa?.LookupConfig?.PathRegex.startsWith(\n                        currentRouteBase\n                    );\n                });\n\n                routeMap[currentRouteBase] =\n                    filteredAppLookups.reduce((prevAppMap, appLookup) => {\n                        const appMap: any = {\n                            ...prevAppMap,\n                        };\n\n                        appMap[appLookup] = this.Applications[appLookup];\n\n                        return appMap;\n                    }, {}) || {};\n\n                workingAppLookups = workingAppLookups.filter((wa) => {\n                    return filteredAppLookups.indexOf(wa) < 0;\n                });\n\n                return routeMap;\n            }, {}) || {};\n\n        let routeSetKeys = Object.keys(routeSet);\n\n        routeSetKeys = routeSetKeys.sort((a, b) => a.localeCompare(b));\n\n        const routeSetResult = {};\n\n        routeSetKeys.forEach((rsk) => (routeSetResult[rsk] = routeSet[rsk]));\n\n        // console.log(\"App Routes: \",routeSetResult)\n\n        return routeSetResult;\n    }\n\n    treeControl = new FlatTreeControl<FlatNode>(\n        (node: any) => node.level,\n        (node: any) => node.expandable\n    );\n\n    treeFlattener = new MatTreeFlattener(\n        this.transformer,\n        (node) => node.level,\n        (node) => node.expandable,\n        (node) => node.children\n    );\n\n    public DataSource = new MatTreeFlatDataSource(\n        this.treeControl,\n        this.treeFlattener\n    );\n\n    @Input('project')\n    public Project: EaCProjectAsCode;\n\n    @Input('project-lookup')\n    public ProjectLookup: string;\n\n    public AppRoute: string;\n\n    // public RoutedApplications: any;\n\n    constructor() {}\n\n    public HasChild = (_: number, node: FlatNode) => node.expandable;\n\n    public ngOnInit(): void {}\n\n    public ngOnChanges() {\n        if (this.Projects && this.ProjectLookups && this.Applications) {\n            let temp = this.BuildProjectTree();\n            // console.log(\"to string: \", JSON.stringify(temp))\n\n            if (JSON.stringify(this.DataSource.data) !== JSON.stringify(temp)) {\n                // console.log('Its different')\n                this.DataSource.data = temp;\n            }\n        }\n    }\n\n    public RouteToPath(path: string): void {\n        window.location.href = path;\n    }\n\n    public BuildProjectTree(): Array<TreeNode> {\n        console.log('calling build project tree');\n        let tempTreeData: Array<TreeNode> = [];\n        this.ProjectLookups?.forEach((pLookup: string) => {\n            let tempProj = this.Projects[pLookup];\n            this.Project = tempProj;\n            let tempProjNode: TreeNode = {\n                name: tempProj.Project.Name,\n                description: tempProj.Project.Description,\n                lookup: pLookup,\n                url: 'https://' + tempProj.PrimaryHost,\n                routerLink: ['/project', pLookup],\n            };\n\n            let tempRoutes = this.ApplicationRoutes;\n\n            if (tempRoutes) {\n                let tempProjChildren: Array<TreeNode> = [];\n                tempRoutes.forEach((appRoute: string) => {\n                    this.AppRoute = appRoute;\n                    // routerLink: ['/route', this.AppRoute, pLookup],\n                    let tempRouteNode: TreeNode = {\n                        name: this.AppRoute,\n                        url: 'https://' + tempProj.PrimaryHost + this.AppRoute,\n                        routerLink: ['/route', this.AppRoute, pLookup],\n                    };\n\n                    let tempApps = this.CurrentRouteApplicationLookups;\n                    if (tempApps) {\n                        let tempRouteChildren: Array<TreeNode> = [];\n                        tempApps.forEach((appLookup: string) => {\n                            let tempApp =\n                                this.RoutedApplications[this.AppRoute][\n                                    appLookup\n                                ];\n                            let appPath =\n                                tempApp.LookupConfig?.PathRegex.substring(\n                                    0,\n                                    tempApp.LookupConfig?.PathRegex.length - 2\n                                );\n\n                            let tempAppNode: TreeNode = {\n                                lookup: appLookup,\n                                name: tempApp.Application.Name,\n                                url:\n                                    'https://' +\n                                    tempProj.PrimaryHost +\n                                    this.AppRoute,\n                                description: tempApp.Application.Description,\n                                routerLink: [\n                                    '/application',\n                                    appLookup,\n                                    this.AppRoute,\n                                    pLookup,\n                                ],\n                            };\n                            tempRouteChildren.push(tempAppNode);\n                        });\n                        tempRouteNode.children = tempRouteChildren;\n                    }\n                    tempProjChildren.push(tempRouteNode);\n                });\n                tempProjNode.children = tempProjChildren;\n            }\n            tempTreeData.push(tempProjNode);\n        });\n        // console.log('THE TREE: ', tempTreeData);\n        return tempTreeData;\n\n        // return tempTreeData;\n    }\n\n    public BuildRouteTree() {\n        console.log('called route tree');\n        let tempTreeData: Array<TreeNode> = [];\n\n        let tempRoutes = this.ApplicationRoutes;\n        if (tempRoutes) {\n            // let tempProjChildren: Array<TreeNode> = [];\n            tempRoutes.forEach((appRoute: string) => {\n                this.AppRoute = appRoute;\n\n                let tempRouteNode: TreeNode = {\n                    name: this.AppRoute,\n                    url: 'https://' + this.Project?.PrimaryHost + this.AppRoute,\n                    routerLink: ['/route', this.AppRoute, this.ProjectLookup],\n                };\n\n                let tempApps = this.CurrentRouteApplicationLookups;\n                if (tempApps) {\n                    let tempRouteChildren: Array<TreeNode> = [];\n                    tempApps.forEach((appLookup: string) => {\n                        let tempApp =\n                            this.RoutedApplications[this.AppRoute][appLookup];\n                        let tempAppNode: TreeNode = {\n                            lookup: appLookup,\n                            name: tempApp.Application.Name,\n                            url:\n                                'https://' +\n                                this.Project?.PrimaryHost +\n                                this.AppRoute,\n                            description: tempApp.Application.Description,\n                            routerLink: [\n                                '/application',\n                                appLookup,\n                                this.AppRoute,\n                                this.ProjectLookup,\n                            ],\n                        };\n                        tempRouteChildren.push(tempAppNode);\n                    });\n                    tempRouteNode.children = tempRouteChildren;\n                }\n                tempTreeData.push(tempRouteNode);\n            });\n        }\n        return tempTreeData;\n    }\n\n    public HandleRoute(route: string) {\n        console.log('route: ', route);\n    }\n}\n","<!-- TREE -->\n<!-- <ng-container *ngIf=\"ProjectLookups?BuildTree():false\"></ng-container> -->\n<lcu-slotted-card-lg\n    *ngIf=\"ProjectLookups?.length > 0\"\n    class=\"fit-content\"\n    [loading]=\"Loading\"\n    card-title=\"Project\"\n    icon=\"work_outline\"\n    [main-slot-description]=\"ProjectLookups?.length + ' project(s) configured'\"\n    (main-action-clicked)=\"RouteToPath('/dashboard/create-project')\"\n>\n    <!-- <div> -->\n    <ng-container *ngIf=\"DataSource\">\n        <mat-tree [dataSource]=\"DataSource\" [treeControl]=\"treeControl\">\n            <mat-tree-node *matTreeNodeDef=\"let node\" matTreeNodePadding>\n                <a\n                    *ngIf=\"node.routerLink\"\n                    class=\"slot-header-anchor\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </a>\n                <div *ngIf=\"!node.routerLink\" class=\"tree-header\">\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </div>\n                <div\n                    class=\"slot-actions-container\"\n                    fxLayout=\"row\"\n                    fxLayoutAlign=\"space-around center\"\n                >\n                    <a\n                        *ngIf=\"node.routerLink\"\n                        class=\"slot-action-anchor\"\n                        [routerLink]=\"node.routerLink\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Edit {{ node.name }}\"\n                            >edit</mat-icon\n                        >\n                    </a>\n                    <a\n                        class=\"slot-action-anchor\"\n                        [href]=\"node.url\"\n                        target=\"_blank\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Launch {{ node.name }}\"\n                            >launch</mat-icon\n                        >\n                    </a>\n                </div>\n                <!-- <button mat-icon-button></button> -->\n            </mat-tree-node>\n            <mat-tree-node\n                *matTreeNodeDef=\"let node; when: HasChild\"\n                matTreeNodePadding\n            >\n                <button\n                    mat-icon-button\n                    matTreeNodeToggle\n                    [attr.aria-label]=\"'Toggle ' + node.name\"\n                >\n                    <mat-icon class=\"mat-icon-rtl-mirror\">\n                        {{\n                            treeControl.isExpanded(node)\n                                ? \"expand_more\"\n                                : \"chevron_right\"\n                        }}\n                    </mat-icon>\n                </button>\n                <a\n                    *ngIf=\"node.routerLink\"\n                    class=\"slot-header-anchor\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </a>\n                <div *ngIf=\"!node.routerLink\" class=\"tree-header\">\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </div>\n                <div\n                    class=\"slot-actions-container\"\n                    fxLayout=\"row\"\n                    fxLayoutAlign=\"space-around center\"\n                >\n                    <a\n                        *ngIf=\"node.routerLink\"\n                        class=\"slot-action-anchor\"\n                        [routerLink]=\"node.routerLink\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Edit {{ node.name }}\"\n                            >edit</mat-icon\n                        >\n                    </a>\n                    <a\n                        class=\"slot-action-anchor\"\n                        [href]=\"node.url\"\n                        target=\"_blank\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Launch {{ node.name }}\"\n                            >launch</mat-icon\n                        >\n                    </a>\n                </div>\n            </mat-tree-node>\n        </mat-tree>\n    </ng-container>\n</lcu-slotted-card-lg>\n"]}
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"project-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/project-card/project-card.component.ts","../../../../../../projects/common/src/lib/elements/project-card/project-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FlatTreeControl } from '@angular/cdk/tree';\nimport { Component, Input, OnInit } from '@angular/core';\nimport {\n    MatTreeFlatDataSource,\n    MatTreeFlattener,\n} from '@angular/material/tree';\nimport { EaCApplicationAsCode, EaCProjectAsCode } from '@semanticjs/common';\nimport { FlatNode, TreeNode } from '../../models/tree-node.model';\n\n@Component({\n    selector: 'lcu-project-card',\n    templateUrl: './project-card.component.html',\n    styleUrls: ['./project-card.component.scss'],\n})\nexport class ProjectCardComponent implements OnInit {\n    @Input('applications-bank')\n    public ApplicationsBank: Array<EaCApplicationAsCode>;\n\n    @Input('loading')\n    public Loading: boolean;\n\n    @Input('project-lookups')\n    public ProjectLookups: Array<string>;\n\n    @Input('projects')\n    public Projects: Array<EaCProjectAsCode>;\n\n    private transformer = (node: TreeNode, level: number) => {\n        return {\n            expandable: !!node.children && node.children.length > 0,\n            name: node.name,\n            level: level,\n            routerLink: node.routerLink,\n            url: node.url,\n            lookup: node.lookup,\n            description: node.description,\n        };\n    };\n\n    protected get Applications(): {\n        [lookup: string]: EaCApplicationAsCode;\n    } {\n        const apps: { [lookup: string]: EaCApplicationAsCode } = {};\n\n        this.Project?.ApplicationLookups?.forEach((appLookup: string) => {\n            apps[appLookup] = this.ApplicationsBank[appLookup];\n        });\n        return apps;\n    }\n\n    protected get ApplicationRoutes(): Array<string> {\n        return Object.keys(this.RoutedApplications || {});\n    }\n\n    protected get CurrentRouteApplicationLookups(): Array<string> {\n        return Object.keys(this.RoutedApplications[this.AppRoute] || {});\n    }\n\n    protected get RoutedApplications(): {\n        [route: string]: { [lookup: string]: EaCApplicationAsCode };\n    } {\n        const appLookups = Object.keys(this.Applications);\n\n        const apps = appLookups.map(\n            (appLookup) => this.Applications[appLookup]\n        );\n\n        let appRoutes =\n            apps.map((app) => {\n                // console.log(\"App from projects: \", app);\n                return app?.LookupConfig?.PathRegex.replace('.*', '');\n            }) || [];\n\n        appRoutes = appRoutes.filter((ar) => ar != null);\n\n        let routeBases: string[] = [];\n\n        appRoutes.forEach((appRoute) => {\n            const appRouteParts = appRoute.split('/');\n\n            const appRouteBase = `/${appRouteParts[1]}`;\n\n            if (routeBases.indexOf(appRouteBase) < 0) {\n                routeBases.push(appRouteBase);\n            }\n        });\n\n        let workingAppLookups = [...(appLookups || [])];\n\n        routeBases = routeBases.sort((a, b) => b.localeCompare(a));\n\n        const routeSet =\n            routeBases.reduce((prevRouteMap, currentRouteBase) => {\n                const routeMap = {\n                    ...prevRouteMap,\n                };\n\n                const filteredAppLookups = workingAppLookups.filter((wal) => {\n                    const wa = this.Applications[wal];\n\n                    return wa?.LookupConfig?.PathRegex.startsWith(\n                        currentRouteBase\n                    );\n                });\n\n                routeMap[currentRouteBase] =\n                    filteredAppLookups.reduce((prevAppMap, appLookup) => {\n                        const appMap: any = {\n                            ...prevAppMap,\n                        };\n\n                        appMap[appLookup] = this.Applications[appLookup];\n\n                        return appMap;\n                    }, {}) || {};\n\n                workingAppLookups = workingAppLookups.filter((wa) => {\n                    return filteredAppLookups.indexOf(wa) < 0;\n                });\n\n                return routeMap;\n            }, {}) || {};\n\n        let routeSetKeys = Object.keys(routeSet);\n\n        routeSetKeys = routeSetKeys.sort((a, b) => a.localeCompare(b));\n\n        const routeSetResult = {};\n\n        routeSetKeys.forEach((rsk) => (routeSetResult[rsk] = routeSet[rsk]));\n\n        // console.log(\"App Routes: \",routeSetResult)\n\n        return routeSetResult;\n    }\n\n    treeControl = new FlatTreeControl<FlatNode>(\n        (node: any) => node.level,\n        (node: any) => node.expandable\n    );\n\n    treeFlattener = new MatTreeFlattener(\n        this.transformer,\n        (node) => node.level,\n        (node) => node.expandable,\n        (node) => node.children\n    );\n\n    public DataSource = new MatTreeFlatDataSource(\n        this.treeControl,\n        this.treeFlattener\n    );\n\n    @Input('project')\n    public Project: EaCProjectAsCode;\n\n    @Input('project-lookup')\n    public ProjectLookup: string;\n\n    public AppRoute: string;\n\n    // public RoutedApplications: any;\n\n    constructor() {}\n\n    public HasChild = (_: number, node: FlatNode) => node.expandable;\n\n    public ngOnInit(): void {}\n\n    public ngOnChanges() {\n        if (this.Projects && this.ProjectLookups && this.Applications) {\n            let temp = this.BuildProjectTree();\n            // console.log(\"to string: \", JSON.stringify(temp))\n\n            if (JSON.stringify(this.DataSource.data) !== JSON.stringify(temp)) {\n                // console.log('Its different')\n                this.DataSource.data = temp;\n            }\n        }\n    }\n\n    public RouteToPath(path: string): void {\n        window.location.href = path;\n    }\n\n    public BuildProjectTree(): Array<TreeNode> {\n        // console.log('calling build project tree');\n        let tempTreeData: Array<TreeNode> = [];\n        this.ProjectLookups?.forEach((pLookup: string) => {\n            let tempProj = this.Projects[pLookup];\n            this.Project = tempProj;\n            let tempProjNode: TreeNode = {\n                name: tempProj.Project.Name,\n                description: tempProj.Project.Description,\n                lookup: pLookup,\n                url: 'https://' + tempProj.PrimaryHost,\n                routerLink: ['/project', pLookup],\n            };\n\n            let tempRoutes = this.ApplicationRoutes;\n\n            if (tempRoutes) {\n                let tempProjChildren: Array<TreeNode> = [];\n                tempRoutes.forEach((appRoute: string) => {\n                    this.AppRoute = appRoute;\n                    // routerLink: ['/route', this.AppRoute, pLookup],\n                    let tempRouteNode: TreeNode = {\n                        name: this.AppRoute,\n                        url: 'https://' + tempProj.PrimaryHost + this.AppRoute,\n                        routerLink: ['/route', this.AppRoute, pLookup],\n                    };\n\n                    let tempApps = this.CurrentRouteApplicationLookups;\n                    if (tempApps) {\n                        let tempRouteChildren: Array<TreeNode> = [];\n                        tempApps.forEach((appLookup: string) => {\n                            let tempApp =\n                                this.RoutedApplications[this.AppRoute][\n                                    appLookup\n                                ];\n                            let appPath =\n                                tempApp.LookupConfig?.PathRegex.substring(\n                                    0,\n                                    tempApp.LookupConfig?.PathRegex.length - 2\n                                );\n\n                            let tempAppNode: TreeNode = {\n                                lookup: appLookup,\n                                name: tempApp.Application.Name,\n                                url:\n                                    'https://' +\n                                    tempProj.PrimaryHost +\n                                    this.AppRoute,\n                                description: tempApp.Application.Description,\n                                routerLink: [\n                                    '/application',\n                                    appLookup,\n                                    this.AppRoute,\n                                    pLookup,\n                                ],\n                            };\n                            tempRouteChildren.push(tempAppNode);\n                        });\n                        tempRouteNode.children = tempRouteChildren;\n                    }\n                    tempProjChildren.push(tempRouteNode);\n                });\n                tempProjNode.children = tempProjChildren;\n            }\n            tempTreeData.push(tempProjNode);\n        });\n        // console.log('THE TREE: ', tempTreeData);\n        return tempTreeData;\n\n        // return tempTreeData;\n    }\n\n    public BuildRouteTree() {\n        console.log('called route tree');\n        let tempTreeData: Array<TreeNode> = [];\n\n        let tempRoutes = this.ApplicationRoutes;\n        if (tempRoutes) {\n            // let tempProjChildren: Array<TreeNode> = [];\n            tempRoutes.forEach((appRoute: string) => {\n                this.AppRoute = appRoute;\n\n                let tempRouteNode: TreeNode = {\n                    name: this.AppRoute,\n                    url: 'https://' + this.Project?.PrimaryHost + this.AppRoute,\n                    routerLink: ['/route', this.AppRoute, this.ProjectLookup],\n                };\n\n                let tempApps = this.CurrentRouteApplicationLookups;\n                if (tempApps) {\n                    let tempRouteChildren: Array<TreeNode> = [];\n                    tempApps.forEach((appLookup: string) => {\n                        let tempApp =\n                            this.RoutedApplications[this.AppRoute][appLookup];\n                        let tempAppNode: TreeNode = {\n                            lookup: appLookup,\n                            name: tempApp.Application.Name,\n                            url:\n                                'https://' +\n                                this.Project?.PrimaryHost +\n                                this.AppRoute,\n                            description: tempApp.Application.Description,\n                            routerLink: [\n                                '/application',\n                                appLookup,\n                                this.AppRoute,\n                                this.ProjectLookup,\n                            ],\n                        };\n                        tempRouteChildren.push(tempAppNode);\n                    });\n                    tempRouteNode.children = tempRouteChildren;\n                }\n                tempTreeData.push(tempRouteNode);\n            });\n        }\n        return tempTreeData;\n    }\n\n    public HandleRoute(route: string) {\n        console.log('route: ', route);\n    }\n}\n","<!-- TREE -->\n<!-- <ng-container *ngIf=\"ProjectLookups?BuildTree():false\"></ng-container> -->\n<lcu-slotted-card-lg\n    *ngIf=\"ProjectLookups?.length > 0\"\n    class=\"fit-content\"\n    [loading]=\"Loading\"\n    card-title=\"Project\"\n    icon=\"work_outline\"\n    [main-slot-description]=\"ProjectLookups?.length + ' project(s) configured'\"\n    (main-action-clicked)=\"RouteToPath('/dashboard/create-project')\"\n>\n    <!-- <div> -->\n    <ng-container *ngIf=\"DataSource\">\n        <mat-tree [dataSource]=\"DataSource\" [treeControl]=\"treeControl\">\n            <mat-tree-node *matTreeNodeDef=\"let node\" matTreeNodePadding>\n                <a\n                    *ngIf=\"node.routerLink\"\n                    class=\"slot-header-anchor\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </a>\n                <div *ngIf=\"!node.routerLink\" class=\"tree-header\">\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </div>\n                <div\n                    class=\"slot-actions-container\"\n                    fxLayout=\"row\"\n                    fxLayoutAlign=\"space-around center\"\n                >\n                    <a\n                        *ngIf=\"node.routerLink\"\n                        class=\"slot-action-anchor\"\n                        [routerLink]=\"node.routerLink\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Edit {{ node.name }}\"\n                            >edit</mat-icon\n                        >\n                    </a>\n                    <a\n                        class=\"slot-action-anchor\"\n                        [href]=\"node.url\"\n                        target=\"_blank\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Launch {{ node.name }}\"\n                            >launch</mat-icon\n                        >\n                    </a>\n                </div>\n                <!-- <button mat-icon-button></button> -->\n            </mat-tree-node>\n            <mat-tree-node\n                *matTreeNodeDef=\"let node; when: HasChild\"\n                matTreeNodePadding\n            >\n                <button\n                    mat-icon-button\n                    matTreeNodeToggle\n                    [attr.aria-label]=\"'Toggle ' + node.name\"\n                >\n                    <mat-icon class=\"mat-icon-rtl-mirror\">\n                        {{\n                            treeControl.isExpanded(node)\n                                ? \"expand_more\"\n                                : \"chevron_right\"\n                        }}\n                    </mat-icon>\n                </button>\n                <a\n                    *ngIf=\"node.routerLink\"\n                    class=\"slot-header-anchor\"\n                    [routerLink]=\"node.routerLink\"\n                >\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </a>\n                <div *ngIf=\"!node.routerLink\" class=\"tree-header\">\n                    <div *ngIf=\"node.name\" class=\"slot-name\">\n                        {{ node.name }}\n                    </div>\n                    <div *ngIf=\"node.description\" class=\"slot-description\">\n                        {{ node.description }}\n                    </div>\n                </div>\n                <div\n                    class=\"slot-actions-container\"\n                    fxLayout=\"row\"\n                    fxLayoutAlign=\"space-around center\"\n                >\n                    <a\n                        *ngIf=\"node.routerLink\"\n                        class=\"slot-action-anchor\"\n                        [routerLink]=\"node.routerLink\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Edit {{ node.name }}\"\n                            >edit</mat-icon\n                        >\n                    </a>\n                    <a\n                        class=\"slot-action-anchor\"\n                        [href]=\"node.url\"\n                        target=\"_blank\"\n                    >\n                        <mat-icon\n                            class=\"action-icon\"\n                            matTooltip=\"Launch {{ node.name }}\"\n                            >launch</mat-icon\n                        >\n                    </a>\n                </div>\n            </mat-tree-node>\n        </mat-tree>\n    </ng-container>\n</lcu-slotted-card-lg>\n"]}