@lowcodeunit/applications-flow-common 1.37.181-integration → 1.37.183-merge
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/controls/build-pipeline-form/build-pipeline-form.component.mjs +17 -16
- package/esm2020/lib/controls/devops-source-control-form/devops-source-control-form.component.mjs +4 -4
- package/esm2020/lib/controls/source-control-form/source-control-form.component.mjs +2 -2
- package/esm2020/lib/elements/applications-card/applications-card.component.mjs +6 -4
- package/esm2020/lib/elements/dashboard-toolbar/dashboard-toolbar.component.mjs +3 -3
- package/esm2020/lib/elements/project-card/project-card.component.mjs +3 -2
- package/esm2020/lib/elements/route-card/route-card.component.mjs +3 -2
- package/fesm2015/lowcodeunit-applications-flow-common.mjs +44 -27
- package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/fesm2020/lowcodeunit-applications-flow-common.mjs +30 -25
- package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/package.json +1 -1
@@ -118,12 +118,13 @@ export class RouteCardComponent {
|
|
118
118
|
let tempRouteChildren = [];
|
119
119
|
tempApps.forEach((appLookup) => {
|
120
120
|
let tempApp = this.RoutedApplications[this.AppRoute][appLookup];
|
121
|
+
let appPath = tempApp.LookupConfig?.PathRegex.substring(0, tempApp.LookupConfig?.PathRegex.length - 2);
|
121
122
|
let tempAppNode = {
|
122
123
|
lookup: appLookup,
|
123
124
|
name: tempApp.Application.Name,
|
124
125
|
url: 'https://' +
|
125
126
|
this.Project?.Hosts[this.Project?.Hosts?.length - 1] +
|
126
|
-
|
127
|
+
appPath,
|
127
128
|
description: tempApp.Application.Description,
|
128
129
|
routerLink: [
|
129
130
|
'/application',
|
@@ -179,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
179
180
|
type: Input,
|
180
181
|
args: ['active-environment-lookup']
|
181
182
|
}] } });
|
182
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"route-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/route-card/route-card.component.ts","../../../../../../projects/common/src/lib/elements/route-card/route-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-route-card',\n    templateUrl: './route-card.component.html',\n    styleUrls: ['./route-card.component.scss'],\n})\nexport class RouteCardComponent implements OnInit {\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    @Input('applications-bank')\n    public ApplicationsBank: Array<EaCApplicationAsCode>;\n\n    @Input('loading')\n    public Loading: boolean;\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 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    public treeControl = new FlatTreeControl<FlatNode>(\n        (node: any) => node.level,\n        (node: any) => node.expandable\n    );\n\n    protected treeFlattener = new MatTreeFlattener(\n        this.transformer,\n        (node: any) => node.level,\n        (node: any) => node.expandable,\n        (node: any) => 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    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    public ApplicationRoutes: Array<string>;\n\n    public AppRoute: string;\n\n    constructor(protected dialog: MatDialog) {}\n\n    public HasChild = (_: number, node: FlatNode) => node.expandable;\n\n    ngOnInit(): void {}\n\n    ngOnChanges() {\n        if (this.ProjectLookup && this.Project) {\n            let temp = this.BuildRouteTree();\n\n            if (JSON.stringify(this.DataSource.data) !== JSON.stringify(temp)) {\n                // console.log('Its different: ', JSON.stringify(temp));\n                this.DataSource.data = temp;\n            }\n        }\n    }\n\n    public BuildRouteTree() {\n        // console.log('called route tree');\n        let tempTreeData: Array<TreeNode> = [];\n\n        this.ApplicationRoutes = Object.keys(this.RoutedApplications || {});\n        if (this.ApplicationRoutes) {\n            // let tempProjChildren: Array<TreeNode> = [];\n            this.ApplicationRoutes.forEach((appRoute: string) => {\n                this.AppRoute = appRoute;\n                // routerLink: ['/route', this.AppRoute, this.ProjectLookup],\n\n                let tempRouteNode: TreeNode = {\n                    name: this.AppRoute,\n                    url:\n                        'https://' +\n                        this.Project?.Hosts[this.Project?.Hosts?.length - 1] +\n                        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?.Hosts[\n                                    this.Project?.Hosts?.length - 1\n                                ] +\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=\"ProjectLookup\"\n    class=\"fit-content\"\n    card-title=\"Route\"\n    button-text=\"Add Route\"\n    icon=\"route\"\n    [loading]=\"Loading\"\n    [main-slot-description]=\"ApplicationRoutes?.length + ' route(s) configured'\"\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"]}
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"route-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/route-card/route-card.component.ts","../../../../../../projects/common/src/lib/elements/route-card/route-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-route-card',\n    templateUrl: './route-card.component.html',\n    styleUrls: ['./route-card.component.scss'],\n})\nexport class RouteCardComponent implements OnInit {\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    @Input('applications-bank')\n    public ApplicationsBank: Array<EaCApplicationAsCode>;\n\n    @Input('loading')\n    public Loading: boolean;\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 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    public treeControl = new FlatTreeControl<FlatNode>(\n        (node: any) => node.level,\n        (node: any) => node.expandable\n    );\n\n    protected treeFlattener = new MatTreeFlattener(\n        this.transformer,\n        (node: any) => node.level,\n        (node: any) => node.expandable,\n        (node: any) => 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    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    public ApplicationRoutes: Array<string>;\n\n    public AppRoute: string;\n\n    constructor(protected dialog: MatDialog) {}\n\n    public HasChild = (_: number, node: FlatNode) => node.expandable;\n\n    ngOnInit(): void {}\n\n    ngOnChanges() {\n        if (this.ProjectLookup && this.Project) {\n            let temp = this.BuildRouteTree();\n\n            if (JSON.stringify(this.DataSource.data) !== JSON.stringify(temp)) {\n                // console.log('Its different: ', JSON.stringify(temp));\n                this.DataSource.data = temp;\n            }\n        }\n    }\n\n    public BuildRouteTree() {\n        // console.log('called route tree');\n        let tempTreeData: Array<TreeNode> = [];\n\n        this.ApplicationRoutes = Object.keys(this.RoutedApplications || {});\n        if (this.ApplicationRoutes) {\n            // let tempProjChildren: Array<TreeNode> = [];\n            this.ApplicationRoutes.forEach((appRoute: string) => {\n                this.AppRoute = appRoute;\n                // routerLink: ['/route', this.AppRoute, this.ProjectLookup],\n\n                let tempRouteNode: TreeNode = {\n                    name: this.AppRoute,\n                    url:\n                        'https://' +\n                        this.Project?.Hosts[this.Project?.Hosts?.length - 1] +\n                        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 appPath = 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                                this.Project?.Hosts[\n                                    this.Project?.Hosts?.length - 1\n                                ] +\n                                appPath,\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=\"ProjectLookup\"\n    class=\"fit-content\"\n    card-title=\"Route\"\n    button-text=\"Add Route\"\n    icon=\"route\"\n    [loading]=\"Loading\"\n    [main-slot-description]=\"ApplicationRoutes?.length + ' route(s) configured'\"\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"]}
|
@@ -4265,9 +4265,12 @@ class DevopsSourceControlFormComponent {
|
|
4265
4265
|
}
|
4266
4266
|
SaveSourceControl() {
|
4267
4267
|
const saveEnvReq = {
|
4268
|
-
Environment:
|
4269
|
-
|
4270
|
-
|
4268
|
+
Environment: {
|
4269
|
+
// ...this.Environment,
|
4270
|
+
Sources: this.Environment.Sources || {},
|
4271
|
+
},
|
4272
|
+
// EnvironmentLookup: this.EnvironmentLookup,
|
4273
|
+
// EnterpriseDataTokens: {},
|
4271
4274
|
};
|
4272
4275
|
let source = Object.assign(Object.assign({}, this.EditingSourceControl), { Branches: this.SelectedBranches, MainBranch: this.MainBranchFormControl.value });
|
4273
4276
|
source = Object.assign(Object.assign({}, source), { Type: 'GitHub', Name: `@${this.OrganizationFormControl.value}/${this.RepositoryFormControl.value}`, DevOpsActionTriggerLookups: [this.DevOpsActionLookup], Organization: this.OrganizationFormControl.value, Repository: this.RepositoryFormControl.value });
|
@@ -5501,12 +5504,21 @@ class BuildPipelineFormComponent {
|
|
5501
5504
|
SaveEnvironment() {
|
5502
5505
|
var _a;
|
5503
5506
|
const saveEnvReq = {
|
5504
|
-
Environment:
|
5505
|
-
|
5506
|
-
|
5507
|
+
Environment: {
|
5508
|
+
// ...this.Environment,
|
5509
|
+
Artifacts: this.Environment.Artifacts || {},
|
5510
|
+
// DevOpsActions: this.Environment.DevOpsActions || {},
|
5511
|
+
// Secrets: this.Environment.Secrets || {},
|
5512
|
+
// Sources: this.Environment.Sources || {},
|
5513
|
+
},
|
5514
|
+
// EnvironmentLookup: this.EnvironmentLookup,
|
5515
|
+
// EnterpriseDataTokens: {},
|
5507
5516
|
};
|
5508
5517
|
let artifactLookup;
|
5509
|
-
let artifact =
|
5518
|
+
let artifact = {
|
5519
|
+
// ...this.Artifact,
|
5520
|
+
// ...this.SelectedHostingOptionInputControlValues,
|
5521
|
+
};
|
5510
5522
|
if (!this.ArtifactLookup) {
|
5511
5523
|
artifactLookup = Guid.CreateRaw();
|
5512
5524
|
artifact = Object.assign(Object.assign({}, artifact), { Type: this.SelectedHostingOption.ArtifactType, Name: this.SelectedHostingOption.Name, NPMRegistry: 'https://registry.npmjs.org/' });
|
@@ -5522,14 +5534,14 @@ class BuildPipelineFormComponent {
|
|
5522
5534
|
if ((_a = this.NPMTokenFormControl) === null || _a === void 0 ? void 0 : _a.value) {
|
5523
5535
|
const secretLookup = 'npm-access-token';
|
5524
5536
|
doa.SecretLookups = [secretLookup];
|
5525
|
-
saveEnvReq.Environment.Secrets[secretLookup]
|
5526
|
-
|
5527
|
-
|
5528
|
-
|
5529
|
-
|
5537
|
+
if (!saveEnvReq.Environment.Secrets[secretLookup]) {
|
5538
|
+
saveEnvReq.Environment.Secrets[secretLookup] = {
|
5539
|
+
Name: 'NPM Access Token',
|
5540
|
+
DataTokenLookup: secretLookup,
|
5541
|
+
KnownAs: 'NPM_TOKEN',
|
5542
|
+
};
|
5543
|
+
}
|
5530
5544
|
saveEnvReq.EnterpriseDataTokens[secretLookup] = {
|
5531
|
-
Name: saveEnvReq.Environment.Secrets[secretLookup].Name,
|
5532
|
-
Description: saveEnvReq.Environment.Secrets[secretLookup].Name,
|
5533
5545
|
Value: this.NPMTokenFormControl.value,
|
5534
5546
|
};
|
5535
5547
|
}
|
@@ -5540,6 +5552,7 @@ class BuildPipelineFormComponent {
|
|
5540
5552
|
const doa = Object.assign(Object.assign({}, this.DevOpsAction), { Name: this.DevOpsActionNameFormControl.value });
|
5541
5553
|
saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;
|
5542
5554
|
}
|
5555
|
+
console.log('env req: ', saveEnvReq);
|
5543
5556
|
this.eacSvc.SaveEnvironmentAsCode(saveEnvReq).then((res) => {
|
5544
5557
|
this.ResponseEvent.emit(res);
|
5545
5558
|
});
|
@@ -8333,10 +8346,10 @@ class DashboardToolbarComponent {
|
|
8333
8346
|
}
|
8334
8347
|
}
|
8335
8348
|
DashboardToolbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: DashboardToolbarComponent, deps: [{ token: i1$4.BreakpointObserver }, { token: EaCService }], target: i0.ɵɵFactoryTarget.Component });
|
8336
|
-
DashboardToolbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: DashboardToolbarComponent, selector: "lcu-dashboard-toolbar", inputs: { AppLookup: ["app-lookup", "AppLookup"], ProjectLookups: ["project-lookups", "ProjectLookups"], Loading: ["loading", "Loading"], ProjectLookup: ["project-lookup", "ProjectLookup"] }, ngImport: i0, template: "<mat-toolbar class=\"dashboard-toolbar\">\n <a class=\"toolbar-item\" href=\"/dashboard\" fxLayoutAlign=\"center center\">\n <mat-icon>home</mat-icon>\n </a>\n\n <div class=\"vl\"></div>\n\n <ng-container *ngIf=\"ProjectLookups\">\n <a class=\"toolbar-item\" href=\"/dashboard/enterprise\">Overview</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/projects\">Projects</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a\n *ngIf=\"ProjectLookups?.length > 0 || Loading\"\n class=\"toolbar-item\"\n href=\"/dashboard/devops\"\n >DevOps</a\n >\n <a\n *ngIf=\"ProjectLookups?.length <= 0 && !Loading\"\n matTooltip=\"Add a project to unlock this feature\"\n class=\"toolbar-item disabled\"\n >DevOps</a\n >\n <div class=\"vl\"></div>\n\n <!-- <span>Domains</span> -->\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers\">Mods</a>\n <!-- <span>Manage (krakyn)</span> -->\n </ng-container>\n\n <ng-container *ngIf=\"ProjectLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/project/{{ ProjectLookup }}\"\n >Project Overview</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/applications/{{ ProjectLookup }}\"\n >Routes</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/domains/{{ ProjectLookup }}\"\n >Domains</a\n >\n <div class=\"vl\"></div>\n\n <!-- <a class=\"toolbar-item disabled\" href=\"/dashboard/state-config\"\n >State Config</a\n >\n <div class=\"vl\"></div> -->\n\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers/{{ ProjectLookup }}\"\n >Mods</a\n >\n </ng-container>\n\n <!-- <ng-container *ngIf=\"AppLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/project/{{ ProjectLookup }}\"\n >Project Overview</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/applications/{{ ProjectLookup }}\"\n >Routes</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/domains/{{ ProjectLookup }}\"\n >Domains</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/state-config/{{ ProjectLookup }}/{{ AppLookup }}\"\n >State Config</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers/{{ ProjectLookup }}\"\n >Mods</a\n >\n </ng-container> -->\n</mat-toolbar>\n", styles: [".dashboard-toolbar{background-color:#fff}.toolbar-item{margin:10px;text-decoration:none;color:#000}.vl{border-left:2px solid black;height:20px}.disabled{color:gray;pointer-events:none}@media only screen and (max-width: 959px){.dashboard-toolbar{height:45px}.toolbar-item{font-size:11px;margin:5px}.vl{border-left:1px solid black;height:12px}}\n"], components: [{ type: i4$2.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i7$3.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7$2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
|
8349
|
+
DashboardToolbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: DashboardToolbarComponent, selector: "lcu-dashboard-toolbar", inputs: { AppLookup: ["app-lookup", "AppLookup"], ProjectLookups: ["project-lookups", "ProjectLookups"], Loading: ["loading", "Loading"], ProjectLookup: ["project-lookup", "ProjectLookup"] }, ngImport: i0, template: "<mat-toolbar class=\"dashboard-toolbar\">\n <a class=\"toolbar-item\" href=\"/dashboard\" fxLayoutAlign=\"center center\">\n <mat-icon>home</mat-icon>\n </a>\n\n <div class=\"vl\"></div>\n\n <ng-container *ngIf=\"ProjectLookups && !ProjectLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/enterprise\">Overview</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/projects\">Projects</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a\n *ngIf=\"ProjectLookups?.length > 0 || Loading\"\n class=\"toolbar-item\"\n href=\"/dashboard/devops\"\n >DevOps</a\n >\n <a\n *ngIf=\"ProjectLookups?.length <= 0 && !Loading\"\n matTooltip=\"Add a project to unlock this feature\"\n class=\"toolbar-item disabled\"\n >DevOps</a\n >\n <div class=\"vl\"></div>\n\n <!-- <span>Domains</span> -->\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers\">Mods</a>\n <!-- <span>Manage (krakyn)</span> -->\n </ng-container>\n\n <ng-container *ngIf=\"ProjectLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/project/{{ ProjectLookup }}\"\n >Project Overview</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/applications/{{ ProjectLookup }}\"\n >Routes</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams/{{ ProjectLookup }}\"\n >Teams</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/domains/{{ ProjectLookup }}\"\n >Domains</a\n >\n <div class=\"vl\"></div>\n\n <!-- <a class=\"toolbar-item disabled\" href=\"/dashboard/state-config\"\n >State Config</a\n >\n <div class=\"vl\"></div> -->\n\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers/{{ ProjectLookup }}\"\n >Mods</a\n >\n </ng-container>\n\n <!-- <ng-container *ngIf=\"AppLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/project/{{ ProjectLookup }}\"\n >Project Overview</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/applications/{{ ProjectLookup }}\"\n >Routes</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/domains/{{ ProjectLookup }}\"\n >Domains</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/state-config/{{ ProjectLookup }}/{{ AppLookup }}\"\n >State Config</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers/{{ ProjectLookup }}\"\n >Mods</a\n >\n </ng-container> -->\n</mat-toolbar>\n", styles: [".dashboard-toolbar{background-color:#fff}.toolbar-item{margin:10px;text-decoration:none;color:#000}.vl{border-left:2px solid black;height:20px}.disabled{color:gray;pointer-events:none}@media only screen and (max-width: 959px){.dashboard-toolbar{height:45px}.toolbar-item{font-size:11px;margin:5px}.vl{border-left:1px solid black;height:12px}}\n"], components: [{ type: i4$2.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i7$3.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7$2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
|
8337
8350
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: DashboardToolbarComponent, decorators: [{
|
8338
8351
|
type: Component,
|
8339
|
-
args: [{ selector: 'lcu-dashboard-toolbar', template: "<mat-toolbar class=\"dashboard-toolbar\">\n <a class=\"toolbar-item\" href=\"/dashboard\" fxLayoutAlign=\"center center\">\n <mat-icon>home</mat-icon>\n </a>\n\n <div class=\"vl\"></div>\n\n <ng-container *ngIf=\"ProjectLookups\">\n <a class=\"toolbar-item\" href=\"/dashboard/enterprise\">Overview</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/projects\">Projects</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a\n *ngIf=\"ProjectLookups?.length > 0 || Loading\"\n class=\"toolbar-item\"\n href=\"/dashboard/devops\"\n >DevOps</a\n >\n <a\n *ngIf=\"ProjectLookups?.length <= 0 && !Loading\"\n matTooltip=\"Add a project to unlock this feature\"\n class=\"toolbar-item disabled\"\n >DevOps</a\n >\n <div class=\"vl\"></div>\n\n <!-- <span>Domains</span> -->\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers\">Mods</a>\n <!-- <span>Manage (krakyn)</span> -->\n </ng-container>\n\n <ng-container *ngIf=\"ProjectLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/project/{{ ProjectLookup }}\"\n >Project Overview</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/applications/{{ ProjectLookup }}\"\n >Routes</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/domains/{{ ProjectLookup }}\"\n >Domains</a\n >\n <div class=\"vl\"></div>\n\n <!-- <a class=\"toolbar-item disabled\" href=\"/dashboard/state-config\"\n >State Config</a\n >\n <div class=\"vl\"></div> -->\n\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers/{{ ProjectLookup }}\"\n >Mods</a\n >\n </ng-container>\n\n <!-- <ng-container *ngIf=\"AppLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/project/{{ ProjectLookup }}\"\n >Project Overview</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/applications/{{ ProjectLookup }}\"\n >Routes</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/domains/{{ ProjectLookup }}\"\n >Domains</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/state-config/{{ ProjectLookup }}/{{ AppLookup }}\"\n >State Config</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers/{{ ProjectLookup }}\"\n >Mods</a\n >\n </ng-container> -->\n</mat-toolbar>\n", styles: [".dashboard-toolbar{background-color:#fff}.toolbar-item{margin:10px;text-decoration:none;color:#000}.vl{border-left:2px solid black;height:20px}.disabled{color:gray;pointer-events:none}@media only screen and (max-width: 959px){.dashboard-toolbar{height:45px}.toolbar-item{font-size:11px;margin:5px}.vl{border-left:1px solid black;height:12px}}\n"] }]
|
8352
|
+
args: [{ selector: 'lcu-dashboard-toolbar', template: "<mat-toolbar class=\"dashboard-toolbar\">\n <a class=\"toolbar-item\" href=\"/dashboard\" fxLayoutAlign=\"center center\">\n <mat-icon>home</mat-icon>\n </a>\n\n <div class=\"vl\"></div>\n\n <ng-container *ngIf=\"ProjectLookups && !ProjectLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/enterprise\">Overview</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/projects\">Projects</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a\n *ngIf=\"ProjectLookups?.length > 0 || Loading\"\n class=\"toolbar-item\"\n href=\"/dashboard/devops\"\n >DevOps</a\n >\n <a\n *ngIf=\"ProjectLookups?.length <= 0 && !Loading\"\n matTooltip=\"Add a project to unlock this feature\"\n class=\"toolbar-item disabled\"\n >DevOps</a\n >\n <div class=\"vl\"></div>\n\n <!-- <span>Domains</span> -->\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers\">Mods</a>\n <!-- <span>Manage (krakyn)</span> -->\n </ng-container>\n\n <ng-container *ngIf=\"ProjectLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/project/{{ ProjectLookup }}\"\n >Project Overview</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/applications/{{ ProjectLookup }}\"\n >Routes</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams/{{ ProjectLookup }}\"\n >Teams</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/domains/{{ ProjectLookup }}\"\n >Domains</a\n >\n <div class=\"vl\"></div>\n\n <!-- <a class=\"toolbar-item disabled\" href=\"/dashboard/state-config\"\n >State Config</a\n >\n <div class=\"vl\"></div> -->\n\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers/{{ ProjectLookup }}\"\n >Mods</a\n >\n </ng-container>\n\n <!-- <ng-container *ngIf=\"AppLookup\">\n <a class=\"toolbar-item\" href=\"/dashboard/project/{{ ProjectLookup }}\"\n >Project Overview</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/applications/{{ ProjectLookup }}\"\n >Routes</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/teams\">Teams</a>\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/domains/{{ ProjectLookup }}\"\n >Domains</a\n >\n <div class=\"vl\"></div>\n\n <a\n class=\"toolbar-item\"\n href=\"/dashboard/state-config/{{ ProjectLookup }}/{{ AppLookup }}\"\n >State Config</a\n >\n <div class=\"vl\"></div>\n\n <a class=\"toolbar-item\" href=\"/dashboard/modifiers/{{ ProjectLookup }}\"\n >Mods</a\n >\n </ng-container> -->\n</mat-toolbar>\n", styles: [".dashboard-toolbar{background-color:#fff}.toolbar-item{margin:10px;text-decoration:none;color:#000}.vl{border-left:2px solid black;height:20px}.disabled{color:gray;pointer-events:none}@media only screen and (max-width: 959px){.dashboard-toolbar{height:45px}.toolbar-item{font-size:11px;margin:5px}.vl{border-left:1px solid black;height:12px}}\n"] }]
|
8340
8353
|
}], ctorParameters: function () { return [{ type: i1$4.BreakpointObserver }, { type: EaCService }]; }, propDecorators: { AppLookup: [{
|
8341
8354
|
type: Input,
|
8342
8355
|
args: ['app-lookup']
|
@@ -8475,14 +8488,15 @@ class ProjectCardComponent {
|
|
8475
8488
|
if (tempApps) {
|
8476
8489
|
let tempRouteChildren = [];
|
8477
8490
|
tempApps.forEach((appLookup) => {
|
8478
|
-
var _a;
|
8491
|
+
var _a, _b, _c;
|
8479
8492
|
let tempApp = this.RoutedApplications[this.AppRoute][appLookup];
|
8493
|
+
let appPath = (_a = tempApp.LookupConfig) === null || _a === void 0 ? void 0 : _a.PathRegex.substring(0, ((_b = tempApp.LookupConfig) === null || _b === void 0 ? void 0 : _b.PathRegex.length) - 2);
|
8480
8494
|
let tempAppNode = {
|
8481
8495
|
lookup: appLookup,
|
8482
8496
|
name: tempApp.Application.Name,
|
8483
8497
|
url: 'https://' +
|
8484
|
-
(tempProj === null || tempProj === void 0 ? void 0 : tempProj.Hosts[((
|
8485
|
-
|
8498
|
+
(tempProj === null || tempProj === void 0 ? void 0 : tempProj.Hosts[((_c = tempProj === null || tempProj === void 0 ? void 0 : tempProj.Hosts) === null || _c === void 0 ? void 0 : _c.length) - 1]) +
|
8499
|
+
appPath,
|
8486
8500
|
description: tempApp.Application.Description,
|
8487
8501
|
routerLink: [
|
8488
8502
|
'/application',
|
@@ -8684,14 +8698,15 @@ class RouteCardComponent {
|
|
8684
8698
|
if (tempApps) {
|
8685
8699
|
let tempRouteChildren = [];
|
8686
8700
|
tempApps.forEach((appLookup) => {
|
8687
|
-
var _a, _b, _c;
|
8701
|
+
var _a, _b, _c, _d, _e;
|
8688
8702
|
let tempApp = this.RoutedApplications[this.AppRoute][appLookup];
|
8703
|
+
let appPath = (_a = tempApp.LookupConfig) === null || _a === void 0 ? void 0 : _a.PathRegex.substring(0, ((_b = tempApp.LookupConfig) === null || _b === void 0 ? void 0 : _b.PathRegex.length) - 2);
|
8689
8704
|
let tempAppNode = {
|
8690
8705
|
lookup: appLookup,
|
8691
8706
|
name: tempApp.Application.Name,
|
8692
8707
|
url: 'https://' +
|
8693
|
-
((
|
8694
|
-
|
8708
|
+
((_c = this.Project) === null || _c === void 0 ? void 0 : _c.Hosts[((_e = (_d = this.Project) === null || _d === void 0 ? void 0 : _d.Hosts) === null || _e === void 0 ? void 0 : _e.length) - 1]) +
|
8709
|
+
appPath,
|
8695
8710
|
description: tempApp.Application.Description,
|
8696
8711
|
routerLink: [
|
8697
8712
|
'/application',
|
@@ -8828,10 +8843,10 @@ class ApplicationsCardComponent {
|
|
8828
8843
|
}
|
8829
8844
|
ngOnInit() { }
|
8830
8845
|
ngOnChanges() {
|
8831
|
-
console.log('app bank: ', this.ApplicationsBank);
|
8846
|
+
// console.log('app bank: ', this.ApplicationsBank);
|
8832
8847
|
if (this.ApplicationsBank) {
|
8833
8848
|
let temp = this.BuildProjectTree();
|
8834
|
-
console.log('to string: ', JSON.stringify(temp));
|
8849
|
+
// console.log('to string: ', JSON.stringify(temp));
|
8835
8850
|
if (JSON.stringify(this.DataSource.data) !== JSON.stringify(temp)) {
|
8836
8851
|
// console.log('Its different')
|
8837
8852
|
this.DataSource.data = temp;
|
@@ -8848,14 +8863,16 @@ class ApplicationsCardComponent {
|
|
8848
8863
|
if (tempApps) {
|
8849
8864
|
let tempRouteChildren = [];
|
8850
8865
|
tempApps.forEach((appLookup) => {
|
8851
|
-
var _a, _b, _c;
|
8866
|
+
var _a, _b, _c, _d, _e;
|
8852
8867
|
let tempApp = this.RoutedApplications[this.AppRoute][appLookup];
|
8868
|
+
console.log('tempApp: ', tempApp);
|
8869
|
+
let appPath = (_a = tempApp.LookupConfig) === null || _a === void 0 ? void 0 : _a.PathRegex.substring(0, ((_b = tempApp.LookupConfig) === null || _b === void 0 ? void 0 : _b.PathRegex.length) - 2);
|
8853
8870
|
let tempAppNode = {
|
8854
8871
|
lookup: appLookup,
|
8855
8872
|
name: tempApp.Application.Name,
|
8856
8873
|
url: 'https://' +
|
8857
|
-
((
|
8858
|
-
|
8874
|
+
((_c = this.Project) === null || _c === void 0 ? void 0 : _c.Hosts[((_e = (_d = this.Project) === null || _d === void 0 ? void 0 : _d.Hosts) === null || _e === void 0 ? void 0 : _e.length) - 1]) +
|
8875
|
+
appPath,
|
8859
8876
|
description: tempApp.Application.Description,
|
8860
8877
|
routerLink: [
|
8861
8878
|
'/application',
|