@lowcodeunit/applications-flow-common 1.33.172-lets-get-social-ish → 1.33.173-social-ui
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/lcu.api.mjs +2 -1
- package/esm2020/lib/applications-flow.module.mjs +17 -8
- package/esm2020/lib/controls/processor-details-form/processor-details-form.component.mjs +6 -6
- package/esm2020/lib/controls/security-toggle/security-toggle.component.mjs +9 -8
- package/esm2020/lib/dialogs/new-application-dialog/new-application-dialog.component.mjs +1 -1
- package/esm2020/lib/dialogs/processor-details-dialog/processor-details-dialog.component.mjs +153 -0
- package/esm2020/lib/elements/breadcrumb/breadcrumb.component.mjs +14 -14
- package/esm2020/lib/elements/dynamic-tabs/dynamic-tabs.component.mjs +2 -2
- package/esm2020/lib/elements/feed-card-sm/feed-card-sm.component.mjs +2 -2
- package/esm2020/lib/elements/form-card/form-card.component.mjs +2 -2
- package/esm2020/lib/elements/gh-control/gh-control.component.mjs +2 -2
- package/esm2020/lib/elements/main-feed-card/main-feed-card.component.mjs +2 -2
- package/esm2020/lib/elements/project-info-card/project-info-card.component.mjs +5 -4
- package/esm2020/lib/elements/projects/controls/builds/builds.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/create-project-wizard/create-project-wizard.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/forms/source-control/source-control.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/git-auth/git-auth.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/header/header.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/hosting-details-form-group/hosting-details-form-group.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/project-items/project-items.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/project-tabs/project-tabs.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/apps-flow/npm-package-select/npm-package-select.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/tabs/devops/devops.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/tabs/dfs-modifiers/dfs-modifiers.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/tabs/domains/domains.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/tabs/general/forms/project-details/project-details.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/tabs/general/forms/root-directory/root-directory.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/tabs/general/general.component.mjs +2 -2
- package/esm2020/lib/elements/projects/projects.component.mjs +2 -2
- package/esm2020/lib/elements/slotted-card/slotted-card.component.mjs +15 -12
- package/esm2020/lib/elements/three-column/three-column.component.mjs +3 -3
- package/esm2020/lib/services/eac.service.mjs +3 -3
- package/fesm2015/lowcodeunit-applications-flow-common.mjs +248 -90
- package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/fesm2020/lowcodeunit-applications-flow-common.mjs +241 -87
- package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/lcu.api.d.ts +1 -0
- package/lib/applications-flow.module.d.ts +10 -8
- package/lib/controls/processor-details-form/processor-details-form.component.d.ts +3 -2
- package/lib/controls/security-toggle/security-toggle.component.d.ts +1 -0
- package/lib/dialogs/processor-details-dialog/processor-details-dialog.component.d.ts +31 -0
- package/lib/elements/breadcrumb/breadcrumb.component.d.ts +3 -3
- package/lib/elements/project-info-card/project-info-card.component.d.ts +2 -1
- package/lib/elements/slotted-card/slotted-card.component.d.ts +7 -3
- package/lib/services/eac.service.d.ts +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { Component, Inject, ViewChild } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
|
+
import { Guid } from '@lcu/common';
|
|
4
|
+
import { ProcessorDetailsFormComponent } from '../../controls/processor-details-form/processor-details-form.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services/eac.service";
|
|
7
|
+
import * as i2 from "@angular/material/dialog";
|
|
8
|
+
import * as i3 from "@angular/material/button";
|
|
9
|
+
import * as i4 from "@angular/material/icon";
|
|
10
|
+
import * as i5 from "../../controls/processor-details-form/processor-details-form.component";
|
|
11
|
+
import * as i6 from "@angular/flex-layout/flex";
|
|
12
|
+
export class ProcessorDetailsDialogComponent {
|
|
13
|
+
constructor(eacSvc, dialogRef, data) {
|
|
14
|
+
this.eacSvc = eacSvc;
|
|
15
|
+
this.dialogRef = dialogRef;
|
|
16
|
+
this.data = data;
|
|
17
|
+
}
|
|
18
|
+
get Application() {
|
|
19
|
+
return this.State?.EaC?.Applications[this.data.applicationLookup] || {};
|
|
20
|
+
}
|
|
21
|
+
get Environment() {
|
|
22
|
+
return this.State?.EaC?.Environments[this.data.environmentLookup];
|
|
23
|
+
}
|
|
24
|
+
get SourceControls() {
|
|
25
|
+
return this.Environment?.Sources || {};
|
|
26
|
+
}
|
|
27
|
+
get SourceControlLookups() {
|
|
28
|
+
return Object.keys(this.Environment?.Sources || {});
|
|
29
|
+
}
|
|
30
|
+
get State() {
|
|
31
|
+
return this.eacSvc.State;
|
|
32
|
+
}
|
|
33
|
+
ngOnInit() {
|
|
34
|
+
}
|
|
35
|
+
CloseDialog() {
|
|
36
|
+
this.dialogRef.close();
|
|
37
|
+
}
|
|
38
|
+
SaveProcessorDetails(event) {
|
|
39
|
+
const app = this.Application;
|
|
40
|
+
app.LookupConfig.AllowedMethods =
|
|
41
|
+
this.ProcessorDetailsFormControls.MethodsFormControl?.value
|
|
42
|
+
?.split(' ')
|
|
43
|
+
.filter((v) => !!v);
|
|
44
|
+
app.Processor.Type = this.ProcessorDetailsFormControls.ProcessorType;
|
|
45
|
+
switch (app.Processor.Type) {
|
|
46
|
+
case 'DFS':
|
|
47
|
+
app.Processor.DefaultFile =
|
|
48
|
+
this.ProcessorDetailsFormControls.DefaultFileFormControl.value ||
|
|
49
|
+
'index.html';
|
|
50
|
+
app.LowCodeUnit = {
|
|
51
|
+
Type: this.ProcessorDetailsFormControls.LCUType,
|
|
52
|
+
};
|
|
53
|
+
switch (app.LowCodeUnit.Type) {
|
|
54
|
+
case 'GitHub':
|
|
55
|
+
app.LowCodeUnit.Organization =
|
|
56
|
+
this.SourceControls[this.ProcessorDetailsFormControls.SourceControlFormControl.value].Organization;
|
|
57
|
+
app.LowCodeUnit.Repository =
|
|
58
|
+
this.SourceControls[this.ProcessorDetailsFormControls.SourceControlFormControl.value].Repository;
|
|
59
|
+
app.LowCodeUnit.Build =
|
|
60
|
+
this.ProcessorDetailsFormControls.BuildFormControl.value;
|
|
61
|
+
app.LowCodeUnit.Path =
|
|
62
|
+
this.Environment.DevOpsActions[this.SourceControls[this.ProcessorDetailsFormControls.SourceControlFormControl.value].DevOpsActionTriggerLookups[0]].Path;
|
|
63
|
+
// console.log("sourceControl lookup: ", this.ProcessorDetailsFormControls.SourceControlFormControl.value);
|
|
64
|
+
app.LowCodeUnit.SourceControlLookup =
|
|
65
|
+
this.ProcessorDetailsFormControls.SourceControlFormControl.value;
|
|
66
|
+
break;
|
|
67
|
+
case 'NPM':
|
|
68
|
+
app.LowCodeUnit.Package =
|
|
69
|
+
this.ProcessorDetailsFormControls.PackageFormControl.value;
|
|
70
|
+
app.LowCodeUnit.Version =
|
|
71
|
+
this.ProcessorDetailsFormControls.VersionFormControl.value;
|
|
72
|
+
break;
|
|
73
|
+
case 'WordPress':
|
|
74
|
+
app.LowCodeUnit.APIRoot =
|
|
75
|
+
this.ProcessorDetailsFormControls.APIRootFormControl.value;
|
|
76
|
+
break;
|
|
77
|
+
case 'Zip':
|
|
78
|
+
app.LowCodeUnit.ZipFile =
|
|
79
|
+
this.ProcessorDetailsFormControls.ZipFileFormControl.value;
|
|
80
|
+
break;
|
|
81
|
+
}
|
|
82
|
+
break;
|
|
83
|
+
case 'OAuth':
|
|
84
|
+
app.Processor.Scopes =
|
|
85
|
+
this.ProcessorDetailsFormControls.ScopesFormControl.value.split(' ');
|
|
86
|
+
app.Processor.TokenLookup =
|
|
87
|
+
this.ProcessorDetailsFormControls.TokenLookupFormControl.value;
|
|
88
|
+
app.LowCodeUnit = {
|
|
89
|
+
Type: this.ProcessorDetailsFormControls.LCUType,
|
|
90
|
+
};
|
|
91
|
+
switch (app.LowCodeUnit.Type) {
|
|
92
|
+
case 'GitHubOAuth':
|
|
93
|
+
app.LowCodeUnit.ClientID =
|
|
94
|
+
this.ProcessorDetailsFormControls.ClientIDFormControl.value;
|
|
95
|
+
app.LowCodeUnit.ClientSecret =
|
|
96
|
+
this.ProcessorDetailsFormControls.ClientSecretFormControl.value;
|
|
97
|
+
break;
|
|
98
|
+
}
|
|
99
|
+
break;
|
|
100
|
+
case 'Proxy':
|
|
101
|
+
app.Processor.InboundPath =
|
|
102
|
+
this.ProcessorDetailsFormControls.InboundPathFormControl.value;
|
|
103
|
+
app.LowCodeUnit = {
|
|
104
|
+
Type: this.ProcessorDetailsFormControls.LCUType,
|
|
105
|
+
};
|
|
106
|
+
switch (app.LowCodeUnit.Type) {
|
|
107
|
+
case 'API':
|
|
108
|
+
app.LowCodeUnit.APIRoot =
|
|
109
|
+
this.ProcessorDetailsFormControls.APIRootFormControl.value;
|
|
110
|
+
app.LowCodeUnit.Security =
|
|
111
|
+
this.ProcessorDetailsFormControls.SecurityFormControl.value;
|
|
112
|
+
break;
|
|
113
|
+
case 'SPA':
|
|
114
|
+
app.LowCodeUnit.SPARoot =
|
|
115
|
+
this.ProcessorDetailsFormControls.SPARootFormControl.value;
|
|
116
|
+
break;
|
|
117
|
+
}
|
|
118
|
+
break;
|
|
119
|
+
case 'Redirect':
|
|
120
|
+
app.Processor.IncludeRequest =
|
|
121
|
+
!!this.ProcessorDetailsFormControls.IncludeRequestFormControl.value;
|
|
122
|
+
app.Processor.Permanent =
|
|
123
|
+
!!this.ProcessorDetailsFormControls.PermanentFormControl.value;
|
|
124
|
+
app.Processor.PreserveMethod =
|
|
125
|
+
!!this.ProcessorDetailsFormControls.PreserveMethodFormControl.value;
|
|
126
|
+
app.Processor.Redirect =
|
|
127
|
+
this.ProcessorDetailsFormControls.RedirectFormControl.value;
|
|
128
|
+
break;
|
|
129
|
+
}
|
|
130
|
+
if (!app.LookupConfig.PathRegex.startsWith('/')) {
|
|
131
|
+
app.LookupConfig.PathRegex = `/${app.LookupConfig.PathRegex}`;
|
|
132
|
+
}
|
|
133
|
+
const saveAppReq = {
|
|
134
|
+
ProjectLookup: this.data.projectLookup,
|
|
135
|
+
Application: app,
|
|
136
|
+
ApplicationLookup: this.data.applicationLookup || Guid.CreateRaw(),
|
|
137
|
+
};
|
|
138
|
+
this.eacSvc.SaveApplicationAsCode(saveAppReq);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
ProcessorDetailsDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ProcessorDetailsDialogComponent, deps: [{ token: i1.EaCService }, { token: i2.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
142
|
+
ProcessorDetailsDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: ProcessorDetailsDialogComponent, selector: "lcu-processor-details-dialog", viewQueries: [{ propertyName: "ProcessorDetailsFormControls", first: true, predicate: ProcessorDetailsFormComponent, descendants: true }], ngImport: i0, template: "<div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<lcu-processor-details-form \n more-details \n [editing-application]=\"Application\"\n [editing-application-lookup]=\"data.applicationLookup\" \n [source-control-lookups]=\"SourceControlLookups\"\n [project-lookup]=\"data.projectLookup\"\n (save-form-event)=\"SaveProcessorDetails($event)\"\n>\n</lcu-processor-details-form>\n", styles: [""], components: [{ type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.ProcessorDetailsFormComponent, selector: "lcu-processor-details-form", inputs: ["editing-application", "editing-application-lookup", "has-save-button", "source-control-lookups", "project-lookup"], outputs: ["save-form-event"] }], directives: [{ type: i6.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }] });
|
|
143
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ProcessorDetailsDialogComponent, decorators: [{
|
|
144
|
+
type: Component,
|
|
145
|
+
args: [{ selector: 'lcu-processor-details-dialog', template: "<div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<lcu-processor-details-form \n more-details \n [editing-application]=\"Application\"\n [editing-application-lookup]=\"data.applicationLookup\" \n [source-control-lookups]=\"SourceControlLookups\"\n [project-lookup]=\"data.projectLookup\"\n (save-form-event)=\"SaveProcessorDetails($event)\"\n>\n</lcu-processor-details-form>\n", styles: [""] }]
|
|
146
|
+
}], ctorParameters: function () { return [{ type: i1.EaCService }, { type: i2.MatDialogRef }, { type: undefined, decorators: [{
|
|
147
|
+
type: Inject,
|
|
148
|
+
args: [MAT_DIALOG_DATA]
|
|
149
|
+
}] }]; }, propDecorators: { ProcessorDetailsFormControls: [{
|
|
150
|
+
type: ViewChild,
|
|
151
|
+
args: [ProcessorDetailsFormComponent]
|
|
152
|
+
}] } });
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"processor-details-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/dialogs/processor-details-dialog/processor-details-dialog.component.ts","../../../../../../projects/common/src/lib/dialogs/processor-details-dialog/processor-details-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, OnInit, ViewChild } from '@angular/core';\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { Guid } from '@lcu/common';\nimport { EaCApplicationAsCode, EaCEnvironmentAsCode, EaCSourceControl } from '@semanticjs/common';\nimport { ProcessorDetailsFormComponent } from '../../controls/processor-details-form/processor-details-form.component';\nimport { EaCService, SaveApplicationAsCodeEventRequest } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\n\nexport interface ProcessorDetailsDialogData {\n  applicationLookup: string;\n  environmentLookup: string;\n  projectLookup: string;\n}\n\n@Component({\n  selector: 'lcu-processor-details-dialog',\n  templateUrl: './processor-details-dialog.component.html',\n  styleUrls: ['./processor-details-dialog.component.scss']\n})\n\nexport class ProcessorDetailsDialogComponent implements OnInit {\n\n  @ViewChild(ProcessorDetailsFormComponent)\n  public ProcessorDetailsFormControls: ProcessorDetailsFormComponent;\n\n  public get Application(): EaCApplicationAsCode {\n    return this.State?.EaC?.Applications[this.data.applicationLookup] || {};\n  }\n\n  public get Environment(): EaCEnvironmentAsCode {\n    return this.State?.EaC?.Environments[this.data.environmentLookup];\n  }\n\n  public get SourceControls(): { [lookup: string]: EaCSourceControl } {\n    return this.Environment?.Sources || {};\n  }\n\n  public get SourceControlLookups(): Array<string> {\n    return Object.keys(this.Environment?.Sources || {});\n  }\n\n  public get State(): ApplicationsFlowState {\n    return this.eacSvc.State;\n  }\n\n  constructor(protected eacSvc: EaCService, \n    public dialogRef: MatDialogRef<ProcessorDetailsDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: ProcessorDetailsDialogData) { }\n\n  public ngOnInit(): void {\n  }\n\n  public CloseDialog(){\n    this.dialogRef.close();\n  }\n\n  public SaveProcessorDetails(event: any): void {\n\n    const app: EaCApplicationAsCode = this.Application;\n    app.LookupConfig.AllowedMethods =\n      this.ProcessorDetailsFormControls.MethodsFormControl?.value\n        ?.split(' ')\n        .filter((v: string) => !!v);\n    app.Processor.Type = this.ProcessorDetailsFormControls.ProcessorType;\n\n    switch (app.Processor.Type) {\n      case 'DFS':\n        app.Processor.DefaultFile =\n          this.ProcessorDetailsFormControls.DefaultFileFormControl.value ||\n          'index.html';\n\n        app.LowCodeUnit = {\n          Type: this.ProcessorDetailsFormControls.LCUType,\n        };\n\n        switch (app.LowCodeUnit.Type) {\n          case 'GitHub':\n            app.LowCodeUnit.Organization =\n              this.SourceControls[\n                this.ProcessorDetailsFormControls.SourceControlFormControl.value\n              ].Organization;\n\n            app.LowCodeUnit.Repository =\n              this.SourceControls[\n                this.ProcessorDetailsFormControls.SourceControlFormControl.value\n              ].Repository;\n\n            app.LowCodeUnit.Build =\n              this.ProcessorDetailsFormControls.BuildFormControl.value;\n\n            app.LowCodeUnit.Path =\n              this.Environment.DevOpsActions[\n                this.SourceControls[\n                  this.ProcessorDetailsFormControls.SourceControlFormControl.value\n                ].DevOpsActionTriggerLookups[0]\n              ].Path;\n            // console.log(\"sourceControl lookup: \", this.ProcessorDetailsFormControls.SourceControlFormControl.value);\n\n            app.LowCodeUnit.SourceControlLookup =\n              this.ProcessorDetailsFormControls.SourceControlFormControl.value;\n            break;\n\n          case 'NPM':\n            app.LowCodeUnit.Package =\n              this.ProcessorDetailsFormControls.PackageFormControl.value;\n\n            app.LowCodeUnit.Version =\n              this.ProcessorDetailsFormControls.VersionFormControl.value;\n            break;\n\n          case 'WordPress':\n            app.LowCodeUnit.APIRoot =\n              this.ProcessorDetailsFormControls.APIRootFormControl.value;\n            break;\n\n          case 'Zip':\n            app.LowCodeUnit.ZipFile =\n              this.ProcessorDetailsFormControls.ZipFileFormControl.value;\n            break;\n        }\n        break;\n\n      case 'OAuth':\n        app.Processor.Scopes =\n          this.ProcessorDetailsFormControls.ScopesFormControl.value.split(' ');\n\n        app.Processor.TokenLookup =\n          this.ProcessorDetailsFormControls.TokenLookupFormControl.value;\n\n        app.LowCodeUnit = {\n          Type: this.ProcessorDetailsFormControls.LCUType,\n        };\n\n        switch (app.LowCodeUnit.Type) {\n          case 'GitHubOAuth':\n            app.LowCodeUnit.ClientID =\n              this.ProcessorDetailsFormControls.ClientIDFormControl.value;\n\n            app.LowCodeUnit.ClientSecret =\n              this.ProcessorDetailsFormControls.ClientSecretFormControl.value;\n            break;\n        }\n        break;\n\n      case 'Proxy':\n        app.Processor.InboundPath =\n          this.ProcessorDetailsFormControls.InboundPathFormControl.value;\n\n        app.LowCodeUnit = {\n          Type: this.ProcessorDetailsFormControls.LCUType,\n        };\n\n        switch (app.LowCodeUnit.Type) {\n          case 'API':\n            app.LowCodeUnit.APIRoot =\n              this.ProcessorDetailsFormControls.APIRootFormControl.value;\n\n            app.LowCodeUnit.Security =\n              this.ProcessorDetailsFormControls.SecurityFormControl.value;\n\n            break;\n\n          case 'SPA':\n            app.LowCodeUnit.SPARoot =\n              this.ProcessorDetailsFormControls.SPARootFormControl.value;\n            break;\n        }\n        break;\n\n      case 'Redirect':\n        app.Processor.IncludeRequest =\n          !!this.ProcessorDetailsFormControls.IncludeRequestFormControl.value;\n\n        app.Processor.Permanent =\n          !!this.ProcessorDetailsFormControls.PermanentFormControl.value;\n\n        app.Processor.PreserveMethod =\n          !!this.ProcessorDetailsFormControls.PreserveMethodFormControl.value;\n\n        app.Processor.Redirect =\n          this.ProcessorDetailsFormControls.RedirectFormControl.value;\n        break;\n    }\n\n    if (!app.LookupConfig.PathRegex.startsWith('/')) {\n      app.LookupConfig.PathRegex = `/${app.LookupConfig.PathRegex}`;\n    }\n\n    const saveAppReq: SaveApplicationAsCodeEventRequest = {\n      ProjectLookup: this.data.projectLookup,\n      Application: app,\n      ApplicationLookup: this.data.applicationLookup || Guid.CreateRaw(),\n    };\n\n    this.eacSvc.SaveApplicationAsCode(saveAppReq);\n  }\n\n}\n","<div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n    <button mat-icon-button (click)=\"CloseDialog()\">\n            <mat-icon>cancel</mat-icon>\n    </button>\n</div>\n\n<lcu-processor-details-form \n    more-details \n    [editing-application]=\"Application\"\n    [editing-application-lookup]=\"data.applicationLookup\" \n    [source-control-lookups]=\"SourceControlLookups\"\n    [project-lookup]=\"data.projectLookup\"\n    (save-form-event)=\"SaveProcessorDetails($event)\"\n>\n</lcu-processor-details-form>\n"]}
|
|
@@ -6,20 +6,19 @@ import * as i3 from "@angular/material/icon";
|
|
|
6
6
|
import * as i4 from "@angular/material/menu";
|
|
7
7
|
import * as i5 from "@angular/flex-layout/flex";
|
|
8
8
|
import * as i6 from "@angular/common";
|
|
9
|
-
import * as i7 from "
|
|
9
|
+
import * as i7 from "skeleton-elements/angular";
|
|
10
|
+
import * as i8 from "@angular/router";
|
|
10
11
|
export class BreadcrumbComponent {
|
|
11
12
|
constructor(eacSvc) {
|
|
12
13
|
this.eacSvc = eacSvc;
|
|
13
|
-
|
|
14
|
-
get Enterprise() {
|
|
15
|
-
return (this.State.Enterprises?.find((ent) => ent.Lookup == this.State.ActiveEnterpriseLookup) ?? this.State.Enterprises ? this.State.Enterprises[0] : null);
|
|
14
|
+
this.SkeletonEffect = 'wave';
|
|
16
15
|
}
|
|
17
16
|
get ApplicationsBank() {
|
|
18
17
|
return this.State?.EaC?.Applications || {};
|
|
19
18
|
}
|
|
20
19
|
get Applications() {
|
|
21
20
|
const apps = {};
|
|
22
|
-
this.SelectedProject?.ApplicationLookups
|
|
21
|
+
this.SelectedProject?.ApplicationLookups?.forEach((appLookup) => {
|
|
23
22
|
apps[appLookup] = this.ApplicationsBank[appLookup];
|
|
24
23
|
});
|
|
25
24
|
return apps;
|
|
@@ -47,7 +46,7 @@ export class BreadcrumbComponent {
|
|
|
47
46
|
}) || [];
|
|
48
47
|
appRoutes = appRoutes.filter((ar) => ar != null);
|
|
49
48
|
let routeBases = [];
|
|
50
|
-
appRoutes
|
|
49
|
+
appRoutes?.forEach((appRoute) => {
|
|
51
50
|
const appRouteParts = appRoute.split('/');
|
|
52
51
|
const appRouteBase = `/${appRouteParts[1]}`;
|
|
53
52
|
if (routeBases.indexOf(appRouteBase) < 0) {
|
|
@@ -80,7 +79,7 @@ export class BreadcrumbComponent {
|
|
|
80
79
|
let routeSetKeys = Object.keys(routeSet);
|
|
81
80
|
routeSetKeys = routeSetKeys.sort((a, b) => a.localeCompare(b));
|
|
82
81
|
const routeSetResult = {};
|
|
83
|
-
routeSetKeys
|
|
82
|
+
routeSetKeys?.forEach((rsk) => (routeSetResult[rsk] = routeSet[rsk]));
|
|
84
83
|
return routeSetResult;
|
|
85
84
|
}
|
|
86
85
|
get SelectedProject() {
|
|
@@ -96,17 +95,18 @@ export class BreadcrumbComponent {
|
|
|
96
95
|
// console.log('Selected project: ', this.SelectedProject.Project);
|
|
97
96
|
// console.log('SelectedRoute:', this.SelectedRoute);
|
|
98
97
|
}
|
|
99
|
-
|
|
100
|
-
this.eacSvc.SetActiveEnterprise(entLookup).then(() => { });
|
|
98
|
+
async handleStateChange() {
|
|
101
99
|
}
|
|
102
|
-
async handleStateChange() { }
|
|
103
100
|
}
|
|
104
101
|
BreadcrumbComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: BreadcrumbComponent, deps: [{ token: i1.EaCService }], target: i0.ɵɵFactoryTarget.Component });
|
|
105
|
-
BreadcrumbComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: BreadcrumbComponent, selector: "lcu-breadcrumb", inputs: { ApplicationLookup: ["application-lookup", "ApplicationLookup"], ProjectLookup: ["project-lookup", "ProjectLookup"], SelectedRoute: ["selected-route", "SelectedRoute"] }, ngImport: i0, template: "<div class=\"breadcrumb-container\" fxLayout=\"row\">\n
|
|
102
|
+
BreadcrumbComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: BreadcrumbComponent, selector: "lcu-breadcrumb", inputs: { Enterprise: ["enterprise", "Enterprise"], ApplicationLookup: ["application-lookup", "ApplicationLookup"], ProjectLookup: ["project-lookup", "ProjectLookup"], SelectedRoute: ["selected-route", "SelectedRoute"] }, ngImport: i0, template: "<div class=\"breadcrumb-container\" fxLayout=\"row wrap\">\n\n \n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <ng-container *ngIf=\"State?.Loading\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Enterprise Name</div>\n </ng-container>\n\n <ng-container *ngIf=\"!State?.Loading && Enterprise\">\n <div class=\"crumb-name\" [routerLink]=\"['/enterprises']\">{{Enterprise?.Name}}</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 mat-menu-item [routerLink]=\"['/enterprises']\">\n <span>{{Enterprise?.Name}}</span>\n </button>\n </mat-menu>\n </ng-container>\n\n </div>\n\n <div *ngIf=\"ProjectLookup && SelectedProject\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <span class=\"seperator\">/</span>\n\n <ng-container *ngIf=\"State?.Loading\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Project Name</div>\n </ng-container>\n\n <ng-container *ngIf=\"!State?.Loading\">\n\n <div \n class=\"crumb-name\" \n [routerLink]=\"['/projects', 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 \n \n <mat-menu #projectMenu=\"matMenu\" xPosition=\"before\">\n <button \n mat-menu-item \n *ngFor=\"let projectLookup of ProjectLookups\" \n [routerLink]=\"['/projects', projectLookup]\"\n >\n <span *ngIf=\"Projects[projectLookup]; let pro;\">{{pro.Project?.Name}}</span>\n </button>\n </mat-menu>\n\n </ng-container>\n\n </div>\n\n <div *ngIf=\"SelectedRoute\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <span class=\"seperator\">/</span>\n\n <ng-container *ngIf=\"State?.Loading\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Route Name</div>\n </ng-container>\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div \n class=\"crumb-name\" \n [routerLink]=\"['/routes', 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 mat-menu-item *ngFor=\"let appRoute of Routes\" [routerLink]=\"['/routes', appRoute, ProjectLookup]\">\n <span *ngIf=\"appRoute\">{{appRoute}}</span>\n </button>\n </mat-menu>\n </ng-container>\n\n </div>\n\n <div *ngIf=\"SelectedApplication && ApplicationLookup\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <span class=\"seperator\">/</span>\n\n <ng-container *ngIf=\"State?.Loading\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Application Name</div>\n </ng-container>\n\n <ng-container *ngIf=\"!State?.Loading\">\n\n <div class=\"crumb-name\" \n [routerLink]=\"['/applications', ApplicationLookup, SelectedRoute, ProjectLookup]\"\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 <button mat-menu-item *ngFor=\"let appLookup of CurrentRouteApplicationLookups\"\n [routerLink]=\"['/applications', appLookup, SelectedRoute, ProjectLookup]\">\n <span *ngIf=\"RoutedApplications[SelectedRoute][appLookup];\n let app\">{{app.Application?.Name}}</span>\n </button>\n </mat-menu>\n </ng-container>\n\n </div>\n\n\n</div>\n", styles: [".breadcrumb-container{background-color:#ebecf0;margin:10px 30px}.seperator{font-size:25px;padding:10px}.crumb-name{cursor:pointer}\n"], components: [{ type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i4.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i4.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i5.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i5.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.SkeletonTextDirective, selector: "[skeleton-text]", inputs: ["effect"] }, { type: i8.RouterLink, selector: ":not(a):not(area)[routerLink]", inputs: ["queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }, { type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
106
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: BreadcrumbComponent, decorators: [{
|
|
107
104
|
type: Component,
|
|
108
|
-
args: [{ selector: 'lcu-breadcrumb', template: "<div class=\"breadcrumb-container\" fxLayout=\"row\">\n
|
|
109
|
-
}], ctorParameters: function () { return [{ type: i1.EaCService }]; }, propDecorators: {
|
|
105
|
+
args: [{ selector: 'lcu-breadcrumb', template: "<div class=\"breadcrumb-container\" fxLayout=\"row wrap\">\n\n \n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <ng-container *ngIf=\"State?.Loading\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Enterprise Name</div>\n </ng-container>\n\n <ng-container *ngIf=\"!State?.Loading && Enterprise\">\n <div class=\"crumb-name\" [routerLink]=\"['/enterprises']\">{{Enterprise?.Name}}</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 mat-menu-item [routerLink]=\"['/enterprises']\">\n <span>{{Enterprise?.Name}}</span>\n </button>\n </mat-menu>\n </ng-container>\n\n </div>\n\n <div *ngIf=\"ProjectLookup && SelectedProject\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <span class=\"seperator\">/</span>\n\n <ng-container *ngIf=\"State?.Loading\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Project Name</div>\n </ng-container>\n\n <ng-container *ngIf=\"!State?.Loading\">\n\n <div \n class=\"crumb-name\" \n [routerLink]=\"['/projects', 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 \n \n <mat-menu #projectMenu=\"matMenu\" xPosition=\"before\">\n <button \n mat-menu-item \n *ngFor=\"let projectLookup of ProjectLookups\" \n [routerLink]=\"['/projects', projectLookup]\"\n >\n <span *ngIf=\"Projects[projectLookup]; let pro;\">{{pro.Project?.Name}}</span>\n </button>\n </mat-menu>\n\n </ng-container>\n\n </div>\n\n <div *ngIf=\"SelectedRoute\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <span class=\"seperator\">/</span>\n\n <ng-container *ngIf=\"State?.Loading\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Route Name</div>\n </ng-container>\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div \n class=\"crumb-name\" \n [routerLink]=\"['/routes', 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 mat-menu-item *ngFor=\"let appRoute of Routes\" [routerLink]=\"['/routes', appRoute, ProjectLookup]\">\n <span *ngIf=\"appRoute\">{{appRoute}}</span>\n </button>\n </mat-menu>\n </ng-container>\n\n </div>\n\n <div *ngIf=\"SelectedApplication && ApplicationLookup\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <span class=\"seperator\">/</span>\n\n <ng-container *ngIf=\"State?.Loading\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Application Name</div>\n </ng-container>\n\n <ng-container *ngIf=\"!State?.Loading\">\n\n <div class=\"crumb-name\" \n [routerLink]=\"['/applications', ApplicationLookup, SelectedRoute, ProjectLookup]\"\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 <button mat-menu-item *ngFor=\"let appLookup of CurrentRouteApplicationLookups\"\n [routerLink]=\"['/applications', appLookup, SelectedRoute, ProjectLookup]\">\n <span *ngIf=\"RoutedApplications[SelectedRoute][appLookup];\n let app\">{{app.Application?.Name}}</span>\n </button>\n </mat-menu>\n </ng-container>\n\n </div>\n\n\n</div>\n", styles: [".breadcrumb-container{background-color:#ebecf0;margin:10px 30px}.seperator{font-size:25px;padding:10px}.crumb-name{cursor:pointer}\n"] }]
|
|
106
|
+
}], ctorParameters: function () { return [{ type: i1.EaCService }]; }, propDecorators: { Enterprise: [{
|
|
107
|
+
type: Input,
|
|
108
|
+
args: ['enterprise']
|
|
109
|
+
}], ApplicationLookup: [{
|
|
110
110
|
type: Input,
|
|
111
111
|
args: ['application-lookup']
|
|
112
112
|
}], ProjectLookup: [{
|
|
@@ -116,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
116
116
|
type: Input,
|
|
117
117
|
args: ['selected-route']
|
|
118
118
|
}] } });
|
|
119
|
-
//# 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 { Component, Input, OnInit } from '@angular/core';\nimport { EaCApplicationAsCode } from '@semanticjs/common';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-breadcrumb',\n  templateUrl: './breadcrumb.component.html',\n  styleUrls: ['./breadcrumb.component.scss'],\n})\nexport class BreadcrumbComponent implements OnInit {\n  public get Enterprise(): any {\n    return (\n      this.State.Enterprises?.find(\n        (ent) => ent.Lookup == this.State.ActiveEnterpriseLookup\n      ) ?? this.State.Enterprises ? this.State.Enterprises[0] : null\n    );\n  }\n\n  @Input('application-lookup')\n  public ApplicationLookup: string;\n\n  @Input('project-lookup')\n  public ProjectLookup: string;\n\n  @Input('selected-route')\n  public SelectedRoute: string;\n\n  public get ApplicationsBank(): { [lookup: string]: EaCApplicationAsCode } {\n    return this.State?.EaC?.Applications || {};\n  }\n\n  public get Applications(): { [lookup: string]: EaCApplicationAsCode } {\n    const apps: { [lookup: string]: EaCApplicationAsCode } = {};\n\n    this.SelectedProject?.ApplicationLookups.forEach((appLookup: string) => {\n      apps[appLookup] = this.ApplicationsBank[appLookup];\n    });\n    return apps;\n  }\n\n  public get SelectedApplication(): EaCApplicationAsCode {\n    return this.State?.EaC?.Applications[this.ApplicationLookup] || {};\n  }\n\n  public get CurrentRouteApplicationLookups(): Array<string> {\n    return Object.keys(this.RoutedApplications[this.SelectedRoute] || {});\n  }\n\n  public get Projects(): any {\n    return this.State?.EaC?.Projects || {};\n  }\n\n  public get ProjectLookups(): string[] {\n    return Object.keys(this.State?.EaC?.Projects || {});\n  }\n\n  public get Routes(): Array<string> {\n    return Object.keys(this.RoutedApplications || {});\n  }\n\n  public get RoutedApplications(): {\n    [route: string]: { [lookup: string]: EaCApplicationAsCode };\n  } {\n    const appLookups = Object.keys(this.Applications);\n\n    const apps = appLookups.map((appLookup) => this.Applications[appLookup]);\n\n    let appRoutes =\n      apps.map((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(currentRouteBase);\n        });\n\n        routeMap[currentRouteBase] =\n          filteredAppLookups.reduce((prevAppMap, appLookup) => {\n            const appMap = {\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    return routeSetResult;\n  }\n\n  public get SelectedProject(): any {\n    return this.State?.EaC?.Projects[this.ProjectLookup] || {};\n  }\n\n  public get State(): ApplicationsFlowState {\n    return this.eacSvc.State;\n  }\n\n  constructor(protected eacSvc: EaCService) {}\n\n  ngOnInit(): void {\n    this.handleStateChange().then((eac) => {});\n\n    // console.log(\"state: \", this.State)\n\n    // console.log(\"selected enterprise: \", this.Enterprise)\n\n    // console.log('Selected project: ', this.SelectedProject.Project);\n\n    // console.log('SelectedRoute:', this.SelectedRoute);\n  }\n\n  public SetActiveEnterprise(entLookup: string): void {\n    this.eacSvc.SetActiveEnterprise(entLookup).then(() => {});\n  }\n\n  protected async handleStateChange(): Promise<void> {}\n}\n","<div class=\"breadcrumb-container\" fxLayout=\"row\">\n  <div *ngIf=\"Enterprise\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n    <div class=\"crumb-name\" [routerLink]=\"['/enterprises']\">\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]=\"['/enterprises']\"\n        (click)=\"SetActiveEnterprise(ent.Lookup)\"\n        *ngFor=\"let ent of State.Enterprises\"\n      >\n        <span>{{ ent.Name }}</span>\n      </button>\n    </mat-menu>\n  </div>\n\n  <div\n    *ngIf=\"ProjectLookup && SelectedProject\"\n    fxLayout=\"row\"\n    fxLayoutAlign=\"center center\"\n  >\n    <span class=\"seperator\">/</span>\n\n    <div class=\"crumb-name\" [routerLink]=\"['/projects', 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      <button\n        mat-menu-item\n        *ngFor=\"let projectLookup of ProjectLookups\"\n        [routerLink]=\"['/projects', projectLookup]\"\n      >\n        <span *ngIf=\"Projects[projectLookup]; let pro\">{{\n          pro.Project.Name\n        }}</span>\n      </button>\n    </mat-menu>\n  </div>\n\n  <div *ngIf=\"SelectedRoute\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n    <span class=\"seperator\">/</span>\n\n    <div\n      class=\"crumb-name\"\n      [routerLink]=\"['/routes', 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]=\"['/routes', appRoute, ProjectLookup]\"\n      >\n        <span *ngIf=\"appRoute\">{{ appRoute }}</span>\n      </button>\n    </mat-menu>\n  </div>\n\n  <div\n    *ngIf=\"SelectedApplication && ApplicationLookup\"\n    fxLayout=\"row\"\n    fxLayoutAlign=\"center center\"\n  >\n    <span class=\"seperator\">/</span>\n\n    <div\n      class=\"crumb-name\"\n      [routerLink]=\"[\n        '/applications',\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      <button\n        mat-menu-item\n        *ngFor=\"let appLookup of CurrentRouteApplicationLookups\"\n        [routerLink]=\"[\n          '/applications',\n          appLookup,\n          SelectedRoute,\n          ProjectLookup\n        ]\"\n      >\n        <span *ngIf=\"RoutedApplications[SelectedRoute][appLookup]; let app\">{{\n          app.Application.Name\n        }}</span>\n      </button>\n    </mat-menu>\n  </div>\n</div>\n"]}
|
|
119
|
+
//# 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 { Component, Input, OnInit } from '@angular/core';\nimport { EaCApplicationAsCode } from '@semanticjs/common';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-breadcrumb',\n  templateUrl: './breadcrumb.component.html',\n  styleUrls: ['./breadcrumb.component.scss'],\n})\nexport class BreadcrumbComponent implements OnInit {\n  @Input('enterprise')\n  public Enterprise: any;\n\n  @Input('application-lookup')\n  public ApplicationLookup: string;\n\n  @Input('project-lookup')\n  public ProjectLookup: string;\n\n  @Input('selected-route')\n  public SelectedRoute: string;\n\n  public get ApplicationsBank(): { [lookup: string]: EaCApplicationAsCode } {\n    return this.State?.EaC?.Applications || {};\n  }\n\n  public get Applications(): { [lookup: string]: EaCApplicationAsCode } {\n    const apps: { [lookup: string]: EaCApplicationAsCode } = {};\n\n    this.SelectedProject?.ApplicationLookups?.forEach((appLookup: string) => {\n      apps[appLookup] = this.ApplicationsBank[appLookup];\n    });\n    return apps;\n  }\n\n  public get SelectedApplication(): EaCApplicationAsCode {\n    return this.State?.EaC?.Applications[this.ApplicationLookup] || {};\n  }\n\n  public get CurrentRouteApplicationLookups(): Array<string> {\n    return Object.keys(this.RoutedApplications[this.SelectedRoute] || {});\n  }\n\n  public get Projects(): any {\n    return this.State?.EaC?.Projects || {};\n  }\n\n  public get ProjectLookups(): string[] {\n    return Object.keys(this.State?.EaC?.Projects || {});\n  }\n\n  public get Routes(): Array<string> {\n    return Object.keys(this.RoutedApplications || {});\n  }\n\n  public get RoutedApplications(): {\n    [route: string]: { [lookup: string]: EaCApplicationAsCode };\n  } {\n    const appLookups = Object.keys(this.Applications);\n\n    const apps = appLookups.map((appLookup) => this.Applications[appLookup]);\n\n    let appRoutes =\n      apps.map((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(currentRouteBase);\n        });\n\n        routeMap[currentRouteBase] =\n          filteredAppLookups.reduce((prevAppMap, appLookup) => {\n            const appMap = {\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    return routeSetResult;\n  }\n\n  public get SelectedProject(): any {\n    return this.State?.EaC?.Projects[this.ProjectLookup] || {};\n  }\n\n  public get State(): ApplicationsFlowState {\n    return this.eacSvc.State;\n  }\n\n  public SkeletonEffect: string;\n\n  constructor(protected eacSvc: EaCService) {\n    this.SkeletonEffect = 'wave';\n  }\n\n  ngOnInit(): void {\n    this.handleStateChange().then((eac) => {});\n\n    // console.log(\"state: \", this.State)\n\n    // console.log(\"selected enterprise: \", this.Enterprise)\n\n\n    // console.log('Selected project: ', this.SelectedProject.Project);\n\n    // console.log('SelectedRoute:', this.SelectedRoute);\n  }\n\n  protected async handleStateChange(): Promise<void> {\n  }\n}\n","<div class=\"breadcrumb-container\" fxLayout=\"row wrap\">\n\n    \n\n    <div  fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n        <ng-container *ngIf=\"State?.Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Enterprise Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!State?.Loading && Enterprise\">\n            <div class=\"crumb-name\" [routerLink]=\"['/enterprises']\">{{Enterprise?.Name}}</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 mat-menu-item [routerLink]=\"['/enterprises']\">\n                <span>{{Enterprise?.Name}}</span>\n                </button>\n            </mat-menu>\n        </ng-container>\n\n    </div>\n\n    <div *ngIf=\"ProjectLookup && SelectedProject\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n        <span class=\"seperator\">/</span>\n\n        <ng-container *ngIf=\"State?.Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Project Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!State?.Loading\">\n\n        <div \n            class=\"crumb-name\" \n            [routerLink]=\"['/projects', 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        \n        \n            <mat-menu #projectMenu=\"matMenu\" xPosition=\"before\">\n                    <button \n                        mat-menu-item \n                        *ngFor=\"let projectLookup of ProjectLookups\" \n                        [routerLink]=\"['/projects', projectLookup]\"\n                    >\n                        <span *ngIf=\"Projects[projectLookup]; let pro;\">{{pro.Project?.Name}}</span>\n                    </button>\n            </mat-menu>\n\n        </ng-container>\n\n    </div>\n\n    <div *ngIf=\"SelectedRoute\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n        <span class=\"seperator\">/</span>\n\n        <ng-container *ngIf=\"State?.Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Route Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!State?.Loading\">\n            <div \n                class=\"crumb-name\" \n                [routerLink]=\"['/routes', 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 mat-menu-item *ngFor=\"let appRoute of Routes\" [routerLink]=\"['/routes', appRoute, ProjectLookup]\">\n                        <span *ngIf=\"appRoute\">{{appRoute}}</span>\n                    </button>\n            </mat-menu>\n        </ng-container>\n\n    </div>\n\n    <div *ngIf=\"SelectedApplication && ApplicationLookup\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n        <span class=\"seperator\">/</span>\n\n        <ng-container *ngIf=\"State?.Loading\">\n            <div skeleton-text [effect]=\"SkeletonEffect\">Application Name</div>\n        </ng-container>\n\n        <ng-container *ngIf=\"!State?.Loading\">\n\n            <div class=\"crumb-name\" \n                [routerLink]=\"['/applications', ApplicationLookup, SelectedRoute, ProjectLookup]\"\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                    <button mat-menu-item *ngFor=\"let appLookup of CurrentRouteApplicationLookups\"\n                    [routerLink]=\"['/applications', appLookup, SelectedRoute, ProjectLookup]\">\n                        <span *ngIf=\"RoutedApplications[SelectedRoute][appLookup];\n                        let app\">{{app.Application?.Name}}</span>\n                    </button>\n            </mat-menu>\n        </ng-container>\n\n    </div>\n\n\n</div>\n"]}
|