@lowcodeunit/applications-flow-common 1.39.59-merge → 1.39.61-exceptions
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/connected-source/connected-source.component.mjs +2 -2
- package/esm2020/lib/controls/devops-source-control-form/devops-source-control-form.component.mjs +15 -9
- package/esm2020/lib/controls/edit-application-form/edit-application-form.component.mjs +3 -3
- package/esm2020/lib/controls/edit-enterprise-form/edit-enterprise-form.component.mjs +3 -3
- package/esm2020/lib/controls/edit-project-form/edit-project-form.component.mjs +2 -2
- package/esm2020/lib/controls/emulated-devices-toggle/emulated-devices-toggle.component.mjs +5 -2
- package/esm2020/lib/controls/feed-comment-form/feed-comment-form.component.mjs +2 -2
- package/esm2020/lib/controls/processor-details-form/processor-details-form.component.mjs +2 -2
- package/esm2020/lib/controls/source-control-form/source-control-form.component.mjs +6 -3
- package/esm2020/lib/controls/state-config-form/state-config-form.component.mjs +2 -2
- package/esm2020/lib/dialogs/add-team-member-dialog/add-team-member-dialog.component.mjs +8 -8
- package/esm2020/lib/dialogs/build-pipeline-dialog/build-pipeline-dialog.component.mjs +2 -2
- package/esm2020/lib/dialogs/edit-application-dialog/edit-application-dialog.component.mjs +2 -2
- package/esm2020/lib/dialogs/edit-enterprise-dialog/edit-enterprise-dialog.component.mjs +3 -3
- package/esm2020/lib/dialogs/edit-project-dialog/edit-project-dialog.component.mjs +2 -2
- package/esm2020/lib/dialogs/feed-header-dialog/feed-header-dialog.component.mjs +7 -4
- package/esm2020/lib/dialogs/new-application-dialog/new-application-dialog.component.mjs +2 -2
- package/esm2020/lib/dialogs/processor-details-dialog/processor-details-dialog.component.mjs +2 -2
- package/esm2020/lib/dialogs/source-control-dialog/source-control-dialog.component.mjs +2 -2
- package/esm2020/lib/elements/applications-card/applications-card.component.mjs +3 -3
- package/esm2020/lib/elements/base-form/base-form.component.mjs +2 -2
- package/esm2020/lib/elements/breadcrumb/breadcrumb.component.mjs +2 -2
- package/esm2020/lib/elements/feed-card-sm/feed-card-sm.component.mjs +2 -2
- package/esm2020/lib/elements/feed-header/feed-header.component.mjs +5 -5
- package/esm2020/lib/elements/form-card/form-card.component.mjs +2 -2
- package/esm2020/lib/elements/main-feed-card/main-feed-card.component.mjs +8 -8
- package/esm2020/lib/elements/project-card/project-card.component.mjs +4 -6
- package/esm2020/lib/elements/project-info-card/project-info-card.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/tabs/apps-flow/apps-flow.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/tabs/general/forms/base-form-test/base-form-test.component.mjs +2 -2
- package/esm2020/lib/elements/question-card/question-card.component.mjs +2 -2
- package/esm2020/lib/services/eac.service.mjs +5 -5
- package/esm2020/lib/services/project.service.mjs +21 -15
- package/fesm2015/lowcodeunit-applications-flow-common.mjs +106 -86
- package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/fesm2020/lowcodeunit-applications-flow-common.mjs +101 -82
- package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/package.json +1 -1
@@ -136,7 +136,7 @@ export class ApplicationsCardComponent {
|
|
136
136
|
// return tempTreeData;
|
137
137
|
}
|
138
138
|
BuildRouteTree() {
|
139
|
-
console.log('called route tree');
|
139
|
+
// console.log('called route tree');
|
140
140
|
let tempTreeData = [];
|
141
141
|
let tempRoutes = this.ApplicationRoutes;
|
142
142
|
if (tempRoutes) {
|
@@ -177,7 +177,7 @@ export class ApplicationsCardComponent {
|
|
177
177
|
return tempTreeData;
|
178
178
|
}
|
179
179
|
HandleRoute(route) {
|
180
|
-
console.log('route: ', route);
|
180
|
+
// console.log('route: ', route);
|
181
181
|
}
|
182
182
|
OpenNewAppDialog(event) {
|
183
183
|
const dialogRef = this.dialog.open(NewApplicationDialogComponent, {
|
@@ -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"]}
|
@@ -45,7 +45,7 @@ export class BaseFormComponent {
|
|
45
45
|
});
|
46
46
|
}
|
47
47
|
save() {
|
48
|
-
console.log('PARENT SAVE');
|
48
|
+
// console.log('PARENT SAVE');
|
49
49
|
}
|
50
50
|
resetForm() { }
|
51
51
|
}
|
@@ -55,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
55
55
|
type: Component,
|
56
56
|
args: [{ selector: 'lcu-base-form', template: "", styles: [""] }]
|
57
57
|
}], ctorParameters: function () { return [{ type: i1.FormsService }, { type: i2.EaCService }]; } });
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1mb3JtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbW1vbi9zcmMvbGliL2VsZW1lbnRzL2Jhc2UtZm9ybS9iYXNlLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tbW9uL3NyYy9saWIvZWxlbWVudHMvYmFzZS1mb3JtL2Jhc2UtZm9ybS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7O0FBU2xELE1BQU0sT0FBTyxpQkFBaUI7SUFrQjFCLFlBQ2MsWUFBMEIsRUFDMUIsR0FBZTtRQURmLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBQzFCLFFBQUcsR0FBSCxHQUFHLENBQVk7SUFDMUIsQ0FBQztJQUVHLFFBQVE7UUFDWCxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVTLFNBQVM7UUFDZixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksR0FBRztZQUNyQixFQUFFLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRO1lBQzVCLElBQUksRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUk7U0FDN0IsQ0FBQztRQUVGLG1CQUFtQjtJQUN2QixDQUFDO0lBRUQ7O09BRUc7SUFDTyxRQUFRLEtBQVUsQ0FBQztJQUVuQixtQkFBbUI7UUFDekIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQVcsRUFBRSxFQUFFO1lBQ3hELElBQ0ksSUFBSSxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQzNCLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUN4QixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FDdkIsRUFDSDtnQkFDRSxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7Z0JBQy9CLHlEQUF5RDtnQkFDekQsSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUM1RDtpQkFBTTtnQkFDSCxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7Z0JBQ2hDLG1CQUFtQjtnQkFDbkIsSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUM7YUFDekM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRDs7T0FFRztJQUNPLGNBQWM7UUFDcEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxxQkFBcUIsQ0FBQztZQUNwQyxFQUFFLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRO1lBQzVCLElBQUksRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUk7U0FDN0IsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVTLElBQUk7UUFDViw4QkFBOEI7SUFDbEMsQ0FBQztJQUVTLFNBQVMsS0FBVSxDQUFDOzs4R0ExRXJCLGlCQUFpQjtrR0FBakIsaUJBQWlCLHFEQ1Y5QixFQUFBOzJGRFVhLGlCQUFpQjtrQkFMN0IsU0FBUzsrQkFDSSxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZUZvcm1Db25maWdNb2RlbCB9IGZyb20gJy4vLi4vLi4vbW9kZWxzL2Jhc2UtZm9ybS1jb25maWcubW9kZWwnO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEVhQ1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9lYWMuc2VydmljZSc7XG5pbXBvcnQgeyBGb3Jtc1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9mb3Jtcy5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdsY3UtYmFzZS1mb3JtJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vYmFzZS1mb3JtLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9iYXNlLWZvcm0uY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQmFzZUZvcm1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIC8qKlxuICAgICAqIEZvcm1Hcm91cCBmb3IgcHJvamVjdCBuYW1lIGNhcmRcbiAgICAgKi9cbiAgICAvLyBwdWJsaWMgRm9ybTogRm9ybUdyb3VwO1xuXG4gICAgLyoqXG4gICAgICogRm9ybSBuYW1lXG4gICAgICovXG4gICAgLy8gcHJvdGVjdGVkIGZvcm1OYW1lOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBXaGVuIGZvcm0gaXMgZGlydHksIHRpZXMgaW50byBmb3Jtc1NlcnZpY2UuRGlzYWJsZUZvcm1zXG4gICAgICovXG4gICAgLy8gcHVibGljIElzRGlydHk6IGJvb2xlYW47XG5cbiAgICBwdWJsaWMgRm9ybUNvbmZpZzogQmFzZUZvcm1Db25maWdNb2RlbDtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcm90ZWN0ZWQgZm9ybXNTZXJ2aWNlOiBGb3Jtc1NlcnZpY2UsXG4gICAgICAgIHByb3RlY3RlZCBlYWM6IEVhQ1NlcnZpY2VcbiAgICApIHt9XG5cbiAgICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2V0dXBGb3JtKCk7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIHNldHVwRm9ybSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5mb3Jtc1NlcnZpY2UuRm9ybSA9IHtcbiAgICAgICAgICAgIElkOiB0aGlzLkZvcm1Db25maWcuRm9ybU5hbWUsXG4gICAgICAgICAgICBGb3JtOiB0aGlzLkZvcm1Db25maWcuRm9ybSxcbiAgICAgICAgfTtcblxuICAgICAgICAvLyB0aGlzLm9uQ2hhbmdlKCk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogTGlzdGVuIHRvIGZvcm0gdmFsdWUgY2hhbmdlc1xuICAgICAqL1xuICAgIHByb3RlY3RlZCBvbkNoYW5nZSgpOiB2b2lkIHt9XG5cbiAgICBwcm90ZWN0ZWQgY2hlY2tGb3JtRm9yQ2hhbmdlcygpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5Gb3JtQ29uZmlnLkZvcm0udmFsdWVDaGFuZ2VzLnN1YnNjcmliZSgodmFsOiBvYmplY3QpID0+IHtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgICB0aGlzLmZvcm1zU2VydmljZS5Gb3JSZWFsVGhvdWdoKFxuICAgICAgICAgICAgICAgICAgICB0aGlzLkZvcm1Db25maWcuRm9ybU5hbWUsXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuRm9ybUNvbmZpZy5Gb3JtXG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5Gb3JtQ29uZmlnLklzRGlydHkgPSB0cnVlO1xuICAgICAgICAgICAgICAgIC8vIGRpc2FibGUgYWxsIGZvcm1zIGV4Y2VwdCB0aGUgY3VycmVudCBmb3JtIGJlaW5nIGVkaXRlZFxuICAgICAgICAgICAgICAgIHRoaXMuZm9ybXNTZXJ2aWNlLkRpc2FibGVGb3Jtcyh0aGlzLkZvcm1Db25maWcuRm9ybU5hbWUpO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICB0aGlzLkZvcm1Db25maWcuSXNEaXJ0eSA9IGZhbHNlO1xuICAgICAgICAgICAgICAgIC8vIGVuYWJsZSBhbGwgZm9ybXNcbiAgICAgICAgICAgICAgICB0aGlzLmZvcm1zU2VydmljZS5EaXNhYmxlRm9ybXMoZmFsc2UpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBVcGRhdGUgRm9ybSB2YWx1ZSByZWZlcmVuY2VcbiAgICAgKi9cbiAgICBwcm90ZWN0ZWQgdXBkYXRlVmFsdWVSZWYoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZm9ybXNTZXJ2aWNlLlVwZGF0ZVZhbHVlc1JlZmVyZW5jZSh7XG4gICAgICAgICAgICBJZDogdGhpcy5Gb3JtQ29uZmlnLkZvcm1OYW1lLFxuICAgICAgICAgICAgRm9ybTogdGhpcy5Gb3JtQ29uZmlnLkZvcm0sXG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBzYXZlKCk6IHZvaWQge1xuICAgICAgICAvLyBjb25zb2xlLmxvZygnUEFSRU5UIFNBVkUnKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgcmVzZXRGb3JtKCk6IHZvaWQge31cbn1cbiIsIiJdfQ==
|
@@ -104,7 +104,7 @@ export class BreadcrumbComponent {
|
|
104
104
|
// rLink = ['/project', this.ProjectLookup];
|
105
105
|
rLink = ['/route', this.SelectedRoute, this.ProjectLookup];
|
106
106
|
}
|
107
|
-
console.log('rlink: ', rLink);
|
107
|
+
// console.log('rlink: ', rLink);
|
108
108
|
return rLink;
|
109
109
|
}
|
110
110
|
}
|
@@ -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\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 = this.RoutedApplications[\n                    this.SelectedRoute\n                ]\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        // console.log('Enterprises: ', this.Enterprises);\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\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 = this.RoutedApplications[\n                    this.SelectedRoute\n                ]\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        // console.log('Enterprises: ', this.Enterprises);\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"]}
|
@@ -12,7 +12,7 @@ export class FeedCardSmComponent {
|
|
12
12
|
}
|
13
13
|
// API Methods
|
14
14
|
HandleAction(action) {
|
15
|
-
console.log('Action clicked');
|
15
|
+
// console.log('Action clicked');
|
16
16
|
}
|
17
17
|
// Helpers
|
18
18
|
determineIcon() {
|
@@ -39,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
39
39
|
type: Input,
|
40
40
|
args: ['feed-item']
|
41
41
|
}] } });
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVlZC1jYXJkLXNtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbW1vbi9zcmMvbGliL2VsZW1lbnRzL2ZlZWQtY2FyZC1zbS9mZWVkLWNhcmQtc20uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tbW9uL3NyYy9saWIvZWxlbWVudHMvZmVlZC1jYXJkLXNtL2ZlZWQtY2FyZC1zbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBUXpELE1BQU0sT0FBTyxtQkFBbUI7SUFRNUIsZ0JBQWUsQ0FBQztJQUVoQixjQUFjO0lBQ1AsUUFBUTtRQUNYLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsZUFBZTtJQUNSLFlBQVksQ0FBQyxNQUFzQjtRQUN0QyxpQ0FBaUM7SUFDckMsQ0FBQztJQUVELFdBQVc7SUFDRCxhQUFhO1FBQ25CLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLENBQUMsRUFBRTtZQUNqQyxJQUFJLENBQUMsSUFBSSxHQUFHLGNBQWMsQ0FBQztZQUUzQixJQUFJLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQztTQUM1QjthQUFNLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLENBQUMsRUFBRTtZQUN4QyxJQUFJLENBQUMsSUFBSSxHQUFHLFFBQVEsQ0FBQztZQUVyQixJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztTQUMxQjthQUFNLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLENBQUMsRUFBRTtZQUN4QyxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQztZQUVuQixJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQztTQUMzQjtJQUNMLENBQUM7O2dIQW5DUSxtQkFBbUI7b0dBQW5CLG1CQUFtQix5R0NSaEMsMHFCQWtCQTsyRkRWYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0ksa0JBQWtCOzBFQU1yQixRQUFRO3NCQURkLEtBQUs7dUJBQUMsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmVlZEl0ZW0sIEZlZWRJdGVtQWN0aW9uIH0gZnJvbSAnLi4vLi4vbW9kZWxzL3VzZXItZmVlZC5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbGN1LWZlZWQtY2FyZC1zbScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2ZlZWQtY2FyZC1zbS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZmVlZC1jYXJkLXNtLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEZlZWRDYXJkU21Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBJbnB1dCgnZmVlZC1pdGVtJylcbiAgICBwdWJsaWMgRmVlZEl0ZW06IEZlZWRJdGVtO1xuXG4gICAgcHVibGljIEljb25Db2xvcjogc3RyaW5nO1xuXG4gICAgcHVibGljIEljb246IHN0cmluZztcblxuICAgIGNvbnN0cnVjdG9yKCkge31cblxuICAgIC8vICBMaWZlIEN5Y2xlXG4gICAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRldGVybWluZUljb24oKTtcbiAgICB9XG5cbiAgICAvLyAgQVBJIE1ldGhvZHNcbiAgICBwdWJsaWMgSGFuZGxlQWN0aW9uKGFjdGlvbjogRmVlZEl0ZW1BY3Rpb24pIHtcbiAgICAgICAgLy8gY29uc29sZS5sb2coJ0FjdGlvbiBjbGlja2VkJyk7XG4gICAgfVxuXG4gICAgLy8gIEhlbHBlcnNcbiAgICBwcm90ZWN0ZWQgZGV0ZXJtaW5lSWNvbigpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuRmVlZEl0ZW0uU3RhdHVzLkNvZGUgPT09IDApIHtcbiAgICAgICAgICAgIHRoaXMuSWNvbiA9ICdjaGVja19jaXJjbGUnO1xuXG4gICAgICAgICAgICB0aGlzLkljb25Db2xvciA9ICdncmVlbic7XG4gICAgICAgIH0gZWxzZSBpZiAodGhpcy5GZWVkSXRlbS5TdGF0dXMuQ29kZSA9PT0gMSkge1xuICAgICAgICAgICAgdGhpcy5JY29uID0gJ2NhbmNlbCc7XG5cbiAgICAgICAgICAgIHRoaXMuSWNvbkNvbG9yID0gJ3JlZCc7XG4gICAgICAgIH0gZWxzZSBpZiAodGhpcy5GZWVkSXRlbS5TdGF0dXMuQ29kZSA9PT0gMikge1xuICAgICAgICAgICAgdGhpcy5JY29uID0gJ3N5bmMnO1xuXG4gICAgICAgICAgICB0aGlzLkljb25Db2xvciA9ICdibHVlJztcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxtYXQtY2FyZCBjbGFzcz1cInNvY2lhbC1jYXJkXCI+XG4gICAgPGRpdiBjbGFzcz1cImZlZWQtY2FyZC1jb250YWluZXJcIiBmeExheW91dD1cInJvd1wiPlxuICAgICAgICA8bWF0LWljb24gKm5nSWY9XCJJY29uXCIgW3N0eWxlLmNvbG9yXT1cIkljb25Db2xvclwiPnt7IEljb24gfX08L21hdC1pY29uPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZmVlZC1jYXJkLW1haW4tY29udGVudFwiPlxuICAgICAgICAgICAgPG1hdC1jYXJkLXRpdGxlICpuZ0lmPVwiRmVlZEl0ZW0uVGl0bGVcIj5cbiAgICAgICAgICAgICAgICB7eyBGZWVkSXRlbS5UaXRsZSB9fVxuICAgICAgICAgICAgPC9tYXQtY2FyZC10aXRsZT5cblxuICAgICAgICAgICAgPGRpdiAqbmdJZj1cIkZlZWRJdGVtLlN1YnRpdGxlXCI+e3sgRmVlZEl0ZW0uU3VidGl0bGUgfX08L2Rpdj5cblxuICAgICAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW21vcmUtZGV0YWlsc11cIj48L25nLWNvbnRlbnQ+XG4gICAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuXG4gICAgPG1hdC1jYXJkLWFjdGlvbnMgZnhMYXlvdXQ9XCJyb3dcIiBmeExheW91dEFsaWduPVwiZW5kXCI+XG4gICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIlthY3Rpb25zXVwiPjwvbmctY29udGVudD5cbiAgICA8L21hdC1jYXJkLWFjdGlvbnM+XG48L21hdC1jYXJkPlxuIl19
|
@@ -104,18 +104,18 @@ export class FeedHeaderComponent {
|
|
104
104
|
switch (this.selectedBtn) {
|
105
105
|
case 'pr-btn':
|
106
106
|
//Pull request
|
107
|
-
console.log('creating pull request: ', this.value);
|
107
|
+
// console.log('creating pull request: ', this.value);
|
108
108
|
break;
|
109
109
|
case 'oi-btn':
|
110
110
|
//Open Issue
|
111
|
-
console.log('Open issue: ', this.value);
|
111
|
+
// console.log('Open issue: ', this.value);
|
112
112
|
break;
|
113
113
|
case 'fb-btn':
|
114
114
|
//Feature Branch
|
115
|
-
console.log('creating feature branch: ', this.value);
|
115
|
+
// console.log('creating feature branch: ', this.value);
|
116
116
|
break;
|
117
117
|
default:
|
118
|
-
console.log('hmm');
|
118
|
+
// console.log('hmm');
|
119
119
|
break;
|
120
120
|
}
|
121
121
|
}
|
@@ -154,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
154
154
|
type: Input,
|
155
155
|
args: ['loading-feed']
|
156
156
|
}] } });
|
157
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feed-header.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/feed-header/feed-header.component.ts","../../../../../../projects/common/src/lib/elements/feed-header/feed-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { FeedHeaderDialogComponent } from '../../dialogs/feed-header-dialog/feed-header-dialog.component';\nimport { NewApplicationDialogComponent } from '../../dialogs/new-application-dialog/new-application-dialog.component';\nimport { FeedItemAction } from '../../models/user-feed.model';\nimport { EaCService } from '../../services/eac.service';\n\n@Component({\n    selector: 'lcu-feed-header',\n    templateUrl: './feed-header.component.html',\n    styleUrls: ['./feed-header.component.scss'],\n})\nexport class FeedHeaderComponent implements OnInit {\n    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    @Input('feed')\n    public Feed: any;\n\n    @Input('feed-check')\n    public FeedCheck: any;\n\n    @Input('source-control-lookup')\n    public SourceControlLookup: string;\n\n    @Input('has-gh-connection')\n    public HasGHConnection: boolean;\n\n    @Input('feed-header-actions')\n    public FeedHeaderActions: Array<FeedItemAction>;\n\n    @Input('loading-feed')\n    public LoadingFeed: boolean;\n\n    // public get ActiveEnvironmentLookup(): string {\n    //     //  TODO:  Eventually support multiple environments\n    //     const envLookups = Object.keys(this.State?.EaC?.Environments || {});\n\n    //     return envLookups[0];\n    // }\n\n    // public get FeedHeaderActions(): Array<FeedItemAction> {\n    //     // console.log('FeedActions: ', this.State?.FeedActions)\n    //     return this.State?.FeedActions;\n    // }\n\n    // public get HasGHConnection(): boolean {\n    //     return this.State?.GitHub?.HasConnection;\n    // }\n\n    // public get State(): ApplicationsFlowState {\n    //     return this.eacSvc.State;\n    // }\n\n    public ModalHeader: string;\n\n    public SkeletonEffect: string;\n\n    protected selectedBtn: string;\n\n    public value: string;\n\n    constructor(protected eacSvc: EaCService, protected dialog: MatDialog) {\n        this.SkeletonEffect = 'wave';\n        // this.selectedBtn = \"pr-btn\";\n    }\n\n    public ngOnInit(): void {}\n\n    public ngOnChanges() {\n        // console.log('feed header actions: ', this.FeedHeaderActions);\n    }\n\n    public ngAfterViewInit() {\n        this.addSelectBtn();\n    }\n\n    public CreateAnnouncement() {\n        // this.ModalHeader = \"Create Team Announcement\";\n        this.OpenFHDialog('Announcement', 'Create Team Announcement');\n    }\n\n    // public CreateFeatureBranch(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Create Feature Branch\";\n    //   this.selectedBtn = \"fb-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"create feature branch selected\");\n    //   this.OpenFHDialog('branch');\n\n    // }\n\n    // public OpenIssue(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Open Issue\";\n    //   this.selectedBtn = \"oi-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"open issue selected\");\n    //   this.OpenFHDialog('issue');\n\n    // }\n\n    // public CreatePullRequest(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Create Pull Request\";\n    //   this.selectedBtn = \"pr-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"create pull request selected\");\n    //   this.OpenFHDialog('pull-request');\n\n    // }\n\n    public CreateNewApp() {\n        const dialogRef = this.dialog.open(NewApplicationDialogComponent, {\n            width: '600px',\n            data: {\n                environmentLookup: this.ActiveEnvironmentLookup,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result: any) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public HandleAction(action: FeedItemAction) {\n        if (action.ActionType == 'Link') {\n            if (action.Action.startsWith('http')) {\n                window.open(action.Action, '_blank');\n            } else {\n                window.location.href = action.Action;\n            }\n        } else if (action.ActionType == 'Modal') {\n            this.OpenFHDialog(action.Action, action.Text);\n        }\n    }\n\n    public OpenFHDialog(modalType: string, modalHeader: string) {\n        const dialogRef = this.dialog.open(FeedHeaderDialogComponent, {\n            width: '600px',\n            data: {\n                dialogTitle: modalHeader,\n                type: modalType,\n                sourceControlLookup: this.SourceControlLookup\n                    ? this.SourceControlLookup\n                    : null,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result: any) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public ReloadFeed(): void {\n        this.eacSvc.ReloadFeed();\n    }\n\n    public RouteToPath(path: string): void {\n        window.location.href = path;\n    }\n\n    public Submit() {\n        console.log('submitting: ', this.value);\n        switch (this.selectedBtn) {\n            case 'pr-btn':\n                //Pull request\n                console.log('creating pull request: ', this.value);\n                break;\n            case 'oi-btn':\n                //Open Issue\n                console.log('Open issue: ', this.value);\n                break;\n            case 'fb-btn':\n                //Feature Branch\n                console.log('creating feature branch: ', this.value);\n                break;\n            default:\n                console.log('hmm');\n\n                break;\n        }\n    }\n\n    //HELPERS\n\n    protected addSelectBtn() {\n        (<HTMLElement>document.getElementById(this.selectedBtn))?.classList.add(\n            'selected'\n        );\n    }\n\n    protected removeSelectedBtn() {\n        (<HTMLElement>(\n            document.getElementById(this.selectedBtn)\n        ))?.classList.remove('selected');\n    }\n}\n","<div>\n    <mat-card class=\"social-card\">\n        <ng-container *ngIf=\"!LoadingFeed && Feed\">\n            <!-- COMMENTED OUT ANNOUNCEMENT BUTTON -->\n            <!-- <div\n                class=\"gh-card-container\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"center center\"\n            >\n                <mat-icon fxFlex=\"15%\" class=\"gh-icon\" color=\"primary\">\n                    campaign\n                </mat-icon>\n                <div fxFlex=\"85%\" class=\"gh-card-main-content\">\n                    <button\n                        mat-raised-button\n                        class=\"main-btn\"\n                        (click)=\"CreateAnnouncement()\"\n                        color=\"primary\"\n                    >\n                        Create Team Announcement\n                    </button>\n\n                </div>\n\n            </div> -->\n\n            <mat-card-actions\n                class=\"feed-header-actions\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"space-around center\"\n            >\n                <ng-container *ngFor=\"let action of FeedHeaderActions\">\n                    <ng-container *ngIf=\"FeedHeaderActions?.length > 2\">\n                        <button\n                            mat-raised-button\n                            [color]=\"action.Color\"\n                            (click)=\"HandleAction(action)\"\n                            class=\"action-btn-sm\"\n                            fxLayoutAlign=\"center center\"\n                        >\n                            <div\n                                fxLayout.gt-md=\"row\"\n                                fxLayout.lt-md=\"column\"\n                                fxLayoutAlign=\"center center\"\n                            >\n                                <mat-icon *ngIf=\"action.Icon\">{{\n                                    action.Icon\n                                }}</mat-icon>\n\n                                <div class=\"action-text\">{{ action.Text }}</div>\n                            </div>\n                        </button>\n                    </ng-container>\n                    <ng-container *ngIf=\"FeedHeaderActions?.length <= 2\">\n                        <button\n                            mat-raised-button\n                            [color]=\"action.Color\"\n                            (click)=\"HandleAction(action)\"\n                            class=\"action-btn-lg\"\n                            fxLayout=\"row\"\n                            fxLayoutAlign=\"center center\"\n                        >\n                            <div\n                                fxLayout.gt-md=\"row\"\n                                fxLayout.lt-md=\"column\"\n                                fxLayoutAlign=\"center center\"\n                            >\n                                <mat-icon *ngIf=\"action.Icon\">{{\n                                    action.Icon\n                                }}</mat-icon>\n                                <div class=\"action-text\">\n                                    {{ action.Text }}\n                                </div>\n                            </div>\n                        </button>\n                    </ng-container>\n                </ng-container>\n            </mat-card-actions>\n        </ng-container>\n\n        <!-- SKELETON -->\n        <ng-container *ngIf=\"LoadingFeed || !Feed\">\n            <!-- COMMENTED OUT SKELETON  FOR ANNOUNCEMENT BTN -->\n            <!-- <div\n                id=\"gh-card-skeleton\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"center center\"\n            >\n                <skeleton-avatar\n                    class=\"gh-icon\"\n                    [showIcon]=\"false\"\n                    [effect]=\"SkeletonEffect\"\n                ></skeleton-avatar>\n\n                <div fxFlex=\"85%\" class=\"gh-card-main-content\">\n                    <skeleton-block\n                        height=\"60px\"\n                        [effect]=\"SkeletonEffect\"\n                    ></skeleton-block>\n                </div>\n\n               \n            </div> -->\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n                <div skeleton-text [effect]=\"SkeletonEffect\">Pull Request</div>\n                <div skeleton-text [effect]=\"SkeletonEffect\">Open Issue</div>\n                <div skeleton-text [effect]=\"SkeletonEffect\">\n                    Feature Branch\n                </div>\n            </div>\n        </ng-container>\n    </mat-card>\n    <!-- <mat-card\n        class=\"social-card reload\"\n        *ngIf=\"FeedCheck\"\n        fxLayout=\"row\"\n        fxLayoutAlign=\"center center\"\n    >\n        <div>There are new items in your feed.</div>\n\n        <button mat-raised-button (click)=\"ReloadFeed()\">Reload Feed</button>\n    </mat-card> -->\n</div>\n"]}
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feed-header.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/feed-header/feed-header.component.ts","../../../../../../projects/common/src/lib/elements/feed-header/feed-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { FeedHeaderDialogComponent } from '../../dialogs/feed-header-dialog/feed-header-dialog.component';\nimport { NewApplicationDialogComponent } from '../../dialogs/new-application-dialog/new-application-dialog.component';\nimport { FeedItemAction } from '../../models/user-feed.model';\nimport { EaCService } from '../../services/eac.service';\n\n@Component({\n    selector: 'lcu-feed-header',\n    templateUrl: './feed-header.component.html',\n    styleUrls: ['./feed-header.component.scss'],\n})\nexport class FeedHeaderComponent implements OnInit {\n    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    @Input('feed')\n    public Feed: any;\n\n    @Input('feed-check')\n    public FeedCheck: any;\n\n    @Input('source-control-lookup')\n    public SourceControlLookup: string;\n\n    @Input('has-gh-connection')\n    public HasGHConnection: boolean;\n\n    @Input('feed-header-actions')\n    public FeedHeaderActions: Array<FeedItemAction>;\n\n    @Input('loading-feed')\n    public LoadingFeed: boolean;\n\n    // public get ActiveEnvironmentLookup(): string {\n    //     //  TODO:  Eventually support multiple environments\n    //     const envLookups = Object.keys(this.State?.EaC?.Environments || {});\n\n    //     return envLookups[0];\n    // }\n\n    // public get FeedHeaderActions(): Array<FeedItemAction> {\n    //     // console.log('FeedActions: ', this.State?.FeedActions)\n    //     return this.State?.FeedActions;\n    // }\n\n    // public get HasGHConnection(): boolean {\n    //     return this.State?.GitHub?.HasConnection;\n    // }\n\n    // public get State(): ApplicationsFlowState {\n    //     return this.eacSvc.State;\n    // }\n\n    public ModalHeader: string;\n\n    public SkeletonEffect: string;\n\n    protected selectedBtn: string;\n\n    public value: string;\n\n    constructor(protected eacSvc: EaCService, protected dialog: MatDialog) {\n        this.SkeletonEffect = 'wave';\n        // this.selectedBtn = \"pr-btn\";\n    }\n\n    public ngOnInit(): void {}\n\n    public ngOnChanges() {\n        // console.log('feed header actions: ', this.FeedHeaderActions);\n    }\n\n    public ngAfterViewInit() {\n        this.addSelectBtn();\n    }\n\n    public CreateAnnouncement() {\n        // this.ModalHeader = \"Create Team Announcement\";\n        this.OpenFHDialog('Announcement', 'Create Team Announcement');\n    }\n\n    // public CreateFeatureBranch(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Create Feature Branch\";\n    //   this.selectedBtn = \"fb-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"create feature branch selected\");\n    //   this.OpenFHDialog('branch');\n\n    // }\n\n    // public OpenIssue(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Open Issue\";\n    //   this.selectedBtn = \"oi-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"open issue selected\");\n    //   this.OpenFHDialog('issue');\n\n    // }\n\n    // public CreatePullRequest(){\n    //   this.removeSelectedBtn();\n    //   this.ModalHeader = \"Create Pull Request\";\n    //   this.selectedBtn = \"pr-btn\";\n    //   this.addSelectBtn();\n    //   console.log(\"create pull request selected\");\n    //   this.OpenFHDialog('pull-request');\n\n    // }\n\n    public CreateNewApp() {\n        const dialogRef = this.dialog.open(NewApplicationDialogComponent, {\n            width: '600px',\n            data: {\n                environmentLookup: this.ActiveEnvironmentLookup,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result: any) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public HandleAction(action: FeedItemAction) {\n        if (action.ActionType == 'Link') {\n            if (action.Action.startsWith('http')) {\n                window.open(action.Action, '_blank');\n            } else {\n                window.location.href = action.Action;\n            }\n        } else if (action.ActionType == 'Modal') {\n            this.OpenFHDialog(action.Action, action.Text);\n        }\n    }\n\n    public OpenFHDialog(modalType: string, modalHeader: string) {\n        const dialogRef = this.dialog.open(FeedHeaderDialogComponent, {\n            width: '600px',\n            data: {\n                dialogTitle: modalHeader,\n                type: modalType,\n                sourceControlLookup: this.SourceControlLookup\n                    ? this.SourceControlLookup\n                    : null,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result: any) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public ReloadFeed(): void {\n        this.eacSvc.ReloadFeed();\n    }\n\n    public RouteToPath(path: string): void {\n        window.location.href = path;\n    }\n\n    public Submit() {\n        console.log('submitting: ', this.value);\n        switch (this.selectedBtn) {\n            case 'pr-btn':\n                //Pull request\n                // console.log('creating pull request: ', this.value);\n                break;\n            case 'oi-btn':\n                //Open Issue\n                // console.log('Open issue: ', this.value);\n                break;\n            case 'fb-btn':\n                //Feature Branch\n                // console.log('creating feature branch: ', this.value);\n                break;\n            default:\n                // console.log('hmm');\n\n                break;\n        }\n    }\n\n    //HELPERS\n\n    protected addSelectBtn() {\n        (<HTMLElement>document.getElementById(this.selectedBtn))?.classList.add(\n            'selected'\n        );\n    }\n\n    protected removeSelectedBtn() {\n        (<HTMLElement>(\n            document.getElementById(this.selectedBtn)\n        ))?.classList.remove('selected');\n    }\n}\n","<div>\n    <mat-card class=\"social-card\">\n        <ng-container *ngIf=\"!LoadingFeed && Feed\">\n            <!-- COMMENTED OUT ANNOUNCEMENT BUTTON -->\n            <!-- <div\n                class=\"gh-card-container\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"center center\"\n            >\n                <mat-icon fxFlex=\"15%\" class=\"gh-icon\" color=\"primary\">\n                    campaign\n                </mat-icon>\n                <div fxFlex=\"85%\" class=\"gh-card-main-content\">\n                    <button\n                        mat-raised-button\n                        class=\"main-btn\"\n                        (click)=\"CreateAnnouncement()\"\n                        color=\"primary\"\n                    >\n                        Create Team Announcement\n                    </button>\n\n                </div>\n\n            </div> -->\n\n            <mat-card-actions\n                class=\"feed-header-actions\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"space-around center\"\n            >\n                <ng-container *ngFor=\"let action of FeedHeaderActions\">\n                    <ng-container *ngIf=\"FeedHeaderActions?.length > 2\">\n                        <button\n                            mat-raised-button\n                            [color]=\"action.Color\"\n                            (click)=\"HandleAction(action)\"\n                            class=\"action-btn-sm\"\n                            fxLayoutAlign=\"center center\"\n                        >\n                            <div\n                                fxLayout.gt-md=\"row\"\n                                fxLayout.lt-md=\"column\"\n                                fxLayoutAlign=\"center center\"\n                            >\n                                <mat-icon *ngIf=\"action.Icon\">{{\n                                    action.Icon\n                                }}</mat-icon>\n\n                                <div class=\"action-text\">{{ action.Text }}</div>\n                            </div>\n                        </button>\n                    </ng-container>\n                    <ng-container *ngIf=\"FeedHeaderActions?.length <= 2\">\n                        <button\n                            mat-raised-button\n                            [color]=\"action.Color\"\n                            (click)=\"HandleAction(action)\"\n                            class=\"action-btn-lg\"\n                            fxLayout=\"row\"\n                            fxLayoutAlign=\"center center\"\n                        >\n                            <div\n                                fxLayout.gt-md=\"row\"\n                                fxLayout.lt-md=\"column\"\n                                fxLayoutAlign=\"center center\"\n                            >\n                                <mat-icon *ngIf=\"action.Icon\">{{\n                                    action.Icon\n                                }}</mat-icon>\n                                <div class=\"action-text\">\n                                    {{ action.Text }}\n                                </div>\n                            </div>\n                        </button>\n                    </ng-container>\n                </ng-container>\n            </mat-card-actions>\n        </ng-container>\n\n        <!-- SKELETON -->\n        <ng-container *ngIf=\"LoadingFeed || !Feed\">\n            <!-- COMMENTED OUT SKELETON  FOR ANNOUNCEMENT BTN -->\n            <!-- <div\n                id=\"gh-card-skeleton\"\n                fxLayout=\"row\"\n                fxLayoutAlign=\"center center\"\n            >\n                <skeleton-avatar\n                    class=\"gh-icon\"\n                    [showIcon]=\"false\"\n                    [effect]=\"SkeletonEffect\"\n                ></skeleton-avatar>\n\n                <div fxFlex=\"85%\" class=\"gh-card-main-content\">\n                    <skeleton-block\n                        height=\"60px\"\n                        [effect]=\"SkeletonEffect\"\n                    ></skeleton-block>\n                </div>\n\n               \n            </div> -->\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n                <div skeleton-text [effect]=\"SkeletonEffect\">Pull Request</div>\n                <div skeleton-text [effect]=\"SkeletonEffect\">Open Issue</div>\n                <div skeleton-text [effect]=\"SkeletonEffect\">\n                    Feature Branch\n                </div>\n            </div>\n        </ng-container>\n    </mat-card>\n    <!-- <mat-card\n        class=\"social-card reload\"\n        *ngIf=\"FeedCheck\"\n        fxLayout=\"row\"\n        fxLayoutAlign=\"center center\"\n    >\n        <div>There are new items in your feed.</div>\n\n        <button mat-raised-button (click)=\"ReloadFeed()\">Reload Feed</button>\n    </mat-card> -->\n</div>\n"]}
|
@@ -11,7 +11,7 @@ export class FormCardComponent {
|
|
11
11
|
ngOnInit() { }
|
12
12
|
ngOnChanges() {
|
13
13
|
if (this.Config) {
|
14
|
-
console.log('recieved Config: ', this.Config);
|
14
|
+
// console.log('recieved Config: ', this.Config);
|
15
15
|
}
|
16
16
|
}
|
17
17
|
}
|
@@ -33,4 +33,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
33
33
|
type: Input,
|
34
34
|
args: ['form']
|
35
35
|
}] } });
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1jYXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbW1vbi9zcmMvbGliL2VsZW1lbnRzL2Zvcm0tY2FyZC9mb3JtLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tbW9uL3NyYy9saWIvZWxlbWVudHMvZm9ybS1jYXJkL2Zvcm0tY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7Ozs7Ozs7QUFRekQsTUFBTSxPQUFPLGlCQUFpQjtJQXNCMUIsZ0JBQWUsQ0FBQztJQUVoQixRQUFRLEtBQVUsQ0FBQztJQUVuQixXQUFXO1FBQ1AsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ2IsaURBQWlEO1NBQ3BEO0lBQ0wsQ0FBQzs7OEdBOUJRLGlCQUFpQjtrR0FBakIsaUJBQWlCLGtOQ1Q5QixxbUVBc0RBOzJGRDdDYSxpQkFBaUI7a0JBTDdCLFNBQVM7K0JBQ0ksZUFBZTswRUFTbEIsTUFBTTtzQkFEWixLQUFLO3VCQUFDLFFBQVE7Z0JBT1IsUUFBUTtzQkFEZCxLQUFLO3VCQUFDLFVBQVU7Z0JBSVYsT0FBTztzQkFEYixLQUFLO3VCQUFDLFVBQVU7Z0JBT1YsSUFBSTtzQkFEVixLQUFLO3VCQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENhcmRGb3JtQ29uZmlnTW9kZWwgfSBmcm9tICcuLi8uLi9tb2RlbHMvY2FyZC1mb3JtLWNvbmZpZy5tb2RlbCc7XG5pbXBvcnQgeyBGb3JtQWN0aW9uc01vZGVsIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2Zvcm0tYWN0aW9ucy5tb2RlbCc7XG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2xjdS1mb3JtLWNhcmQnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9mb3JtLWNhcmQuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2Zvcm0tY2FyZC5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBGb3JtQ2FyZENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgLyoqXG4gICAgICogVmFsdWVzIGZvciBidWlsZGluZyBvdXQgdGhlIGNhcmRcbiAgICAgKi9cbiAgICBASW5wdXQoJ2NvbmZpZycpXG4gICAgcHVibGljIENvbmZpZzogQ2FyZEZvcm1Db25maWdNb2RlbDtcblxuICAgIC8qKlxuICAgICAqIERpc2FibGUgZXZlcnl0aGluZ1xuICAgICAqL1xuICAgIEBJbnB1dCgnZGlzYWJsZWQnKVxuICAgIHB1YmxpYyBEaXNhYmxlZDogYm9vbGVhbjtcblxuICAgIEBJbnB1dCgnaXMtZGlydHknKVxuICAgIHB1YmxpYyBJc0RpcnR5OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogRm9ybVxuICAgICAqL1xuICAgIEBJbnB1dCgnZm9ybScpXG4gICAgcHVibGljIEZvcm06IEZvcm1Hcm91cDtcblxuICAgIGNvbnN0cnVjdG9yKCkge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge31cblxuICAgIG5nT25DaGFuZ2VzKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5Db25maWcpIHtcbiAgICAgICAgICAgIC8vIGNvbnNvbGUubG9nKCdyZWNpZXZlZCBDb25maWc6ICcsIHRoaXMuQ29uZmlnKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxkaXYgW25nQ2xhc3NdPVwiRGlzYWJsZWQgPyAnZm9ybS1kaXNhYmxlZCcgOiAnZm9ybS1lbmFibGVkJ1wiPlxuICAgIDxtYXQtY2FyZD5cbiAgICAgICAgPG1hdC1jYXJkLWhlYWRlcj5cbiAgICAgICAgICAgIDxkaXYgbWF0LWNhcmQtYXZhdGFyPlxuICAgICAgICAgICAgICAgIDxtYXQtaWNvbiBjb2xvcj1cImFjY2VudFwiIGNsYXNzPVwidGl0bGUtaWNvblwiPlxuICAgICAgICAgICAgICAgICAgICB7eyBDb25maWc/Lkljb24gfX1cbiAgICAgICAgICAgICAgICA8L21hdC1pY29uPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8bWF0LWNhcmQtdGl0bGUgY2xhc3M9XCJwYXJhZ3JhcGgtdGl0bGVcIj5cbiAgICAgICAgICAgICAgICB7eyBDb25maWc/LlRpdGxlIH19XG4gICAgICAgICAgICA8L21hdC1jYXJkLXRpdGxlPlxuICAgICAgICAgICAgPG1hdC1jYXJkLXN1YnRpdGxlIGNsYXNzPVwicGxhaW4tdGV4dFwiPlxuICAgICAgICAgICAgICAgIHt7IENvbmZpZz8uU3VidGl0bGUgfX1cbiAgICAgICAgICAgIDwvbWF0LWNhcmQtc3VidGl0bGU+XG4gICAgICAgIDwvbWF0LWNhcmQtaGVhZGVyPlxuICAgICAgICA8bWF0LWNhcmQtY29udGVudCBmeEZsZXhGaWxsIGNsYXNzPVwibWFyZ2luLXRvcC0zXCI+XG4gICAgICAgICAgICA8bmctdGVtcGxhdGUgI2NvbnRlbnQ+XG4gICAgICAgICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJjb250ZW50XCI+IDwvbmctY29udGFpbmVyPlxuICAgICAgICA8L21hdC1jYXJkLWNvbnRlbnQ+XG4gICAgICAgIDxtYXQtY2FyZC1hY3Rpb25zPlxuICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgICpuZ0lmPVwiQ29uZmlnPy5Gb3JtQWN0aW9ucyAmJiBJc0RpcnR5XCJcbiAgICAgICAgICAgICAgICBmeExheW91dD1cInJvd1wiXG4gICAgICAgICAgICAgICAgZnhMYXlvdXRBbGlnbj1cInNwYWNlLWJldHdlZW4gY2VudGVyXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cIm1hdC1zbWFsbCBjYXB0aW9uLXRleHRcIj57e1xuICAgICAgICAgICAgICAgICAgICBDb25maWc/LkZvcm1BY3Rpb25zLk1lc3NhZ2VcbiAgICAgICAgICAgICAgICB9fTwvc3Bhbj5cbiAgICAgICAgICAgICAgICA8ZGl2IGZ4TGF5b3V0QWxpZ249XCJlbmQgY2VudGVyXCI+XG4gICAgICAgICAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgICAgICAgICAgICpuZ0Zvcj1cImxldCBhY3Rpb24gb2YgQ29uZmlnPy5Gb3JtQWN0aW9ucz8uQWN0aW9uc1wiXG4gICAgICAgICAgICAgICAgICAgICAgICBmeExheW91dD1cInJvd1wiXG4gICAgICAgICAgICAgICAgICAgICAgICBmeExheW91dEFsaWduPVwiZW5kIGNlbnRlclwiXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGFzcz1cIm1hcmdpbi1yaWdodC0xXCJcbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgRGlzYWJsZWQgfHxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGFjdGlvbi5UeXBlID09PSAnU0FWRScgJiYgRm9ybS5pbnZhbGlkKVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9XCJ7eyBhY3Rpb24uQ29sb3IgfX1cIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1hdC1mbGF0LWJ1dHRvblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJhY3Rpb24uQ2xpY2tFdmVudCgpXCJcbiAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB7eyBhY3Rpb24uTGFiZWwgfX1cbiAgICAgICAgICAgICAgICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L21hdC1jYXJkLWFjdGlvbnM+XG4gICAgPC9tYXQtY2FyZD5cbjwvZGl2PlxuIl19
|