@lowcodeunit/applications-flow-common 1.33.220-lets-get-social-ish → 1.33.223-lets-get-social-ish
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/dialogs/new-application-dialog/new-application-dialog.component.mjs +55 -59
- package/esm2020/lib/elements/project-info-card/project-info-card.component.mjs +6 -3
- package/fesm2015/lowcodeunit-applications-flow-common.mjs +63 -65
- package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/fesm2020/lowcodeunit-applications-flow-common.mjs +65 -67
- package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/lib/elements/project-info-card/project-info-card.component.d.ts +2 -1
- package/package.json +1 -1
|
@@ -11,8 +11,9 @@ import * as i3 from "@angular/material/button";
|
|
|
11
11
|
import * as i4 from "@angular/material/icon";
|
|
12
12
|
import * as i5 from "../../controls/edit-application-form/edit-application-form.component";
|
|
13
13
|
import * as i6 from "../../controls/processor-details-form/processor-details-form.component";
|
|
14
|
-
import * as i7 from "@
|
|
15
|
-
import * as i8 from "@angular/
|
|
14
|
+
import * as i7 from "@lowcodeunit/app-host-common";
|
|
15
|
+
import * as i8 from "@angular/flex-layout/flex";
|
|
16
|
+
import * as i9 from "@angular/common";
|
|
16
17
|
export class NewApplicationDialogComponent {
|
|
17
18
|
constructor(eacSvc, dialogRef, data) {
|
|
18
19
|
this.eacSvc = eacSvc;
|
|
@@ -43,24 +44,34 @@ export class NewApplicationDialogComponent {
|
|
|
43
44
|
this.NewApplicationLookup = appLookup;
|
|
44
45
|
}
|
|
45
46
|
SaveApplication() {
|
|
46
|
-
const app =
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
47
|
+
const app = {
|
|
48
|
+
Application: {
|
|
49
|
+
Name: this.ApplicationFormControls.NameFormControl.value,
|
|
50
|
+
Description: this.ApplicationFormControls.DescriptionFormControl.value,
|
|
51
|
+
PriorityShift: 0,
|
|
52
|
+
},
|
|
53
|
+
AccessRightLookups: [],
|
|
54
|
+
DataTokens: {},
|
|
55
|
+
LicenseConfigurationLookups: [],
|
|
56
|
+
LookupConfig: {
|
|
57
|
+
IsPrivate: false,
|
|
58
|
+
IsTriggerSignIn: false,
|
|
59
|
+
PathRegex: `${this.ApplicationFormControls.RouteFormControl.value}.*`,
|
|
60
|
+
QueryRegex: '',
|
|
61
|
+
HeaderRegex: '',
|
|
62
|
+
AllowedMethods: this.ProcessorDetailsFormControls.MethodsFormControl?.value
|
|
63
|
+
?.split(' ')
|
|
64
|
+
.filter((v) => !!v),
|
|
65
|
+
},
|
|
66
|
+
Processor: {
|
|
67
|
+
Type: this.ProcessorDetailsFormControls.ProcessorType,
|
|
68
|
+
},
|
|
51
69
|
};
|
|
52
|
-
app.LookupConfig.PathRegex = `${this.ApplicationFormControls.RouteFormControl.value}.*`;
|
|
53
|
-
app.LookupConfig.AllowedMethods =
|
|
54
|
-
this.ProcessorDetailsFormControls.MethodsFormControl?.value
|
|
55
|
-
?.split(' ')
|
|
56
|
-
.filter((v) => !!v);
|
|
57
|
-
app.Processor.Type = this.ProcessorDetailsFormControls.ProcessorType;
|
|
58
70
|
switch (app.Processor.Type) {
|
|
59
71
|
case 'DFS':
|
|
60
|
-
app.Processor.DefaultFile =
|
|
61
|
-
this.ProcessorDetailsFormControls.DefaultFileFormControl.value ||
|
|
62
|
-
'index.html';
|
|
63
72
|
app.Processor.BaseHref = `${this.ApplicationFormControls.RouteFormControl.value}/`.replace('//', '/');
|
|
73
|
+
app.Processor.DefaultFile =
|
|
74
|
+
this.ProcessorDetailsFormControls.DefaultFileFormControl.value || 'index.html';
|
|
64
75
|
app.LowCodeUnit = {
|
|
65
76
|
Type: this.ProcessorDetailsFormControls.LCUType,
|
|
66
77
|
};
|
|
@@ -70,75 +81,51 @@ export class NewApplicationDialogComponent {
|
|
|
70
81
|
this.SourceControls[this.ProcessorDetailsFormControls.SourceControlFormControl.value].Organization;
|
|
71
82
|
app.LowCodeUnit.Repository =
|
|
72
83
|
this.SourceControls[this.ProcessorDetailsFormControls.SourceControlFormControl.value].Repository;
|
|
73
|
-
app.LowCodeUnit.Build =
|
|
74
|
-
this.ProcessorDetailsFormControls.BuildFormControl.value;
|
|
84
|
+
app.LowCodeUnit.Build = this.ProcessorDetailsFormControls.BuildFormControl.value;
|
|
75
85
|
app.LowCodeUnit.Path =
|
|
76
|
-
this.
|
|
77
|
-
// console.log("sourceControl lookup: ", this.ProcessorDetailsFormControls.SourceControlFormControl.value);
|
|
78
|
-
app.LowCodeUnit.SourceControlLookup =
|
|
79
|
-
this.ProcessorDetailsFormControls.SourceControlFormControl.value;
|
|
86
|
+
this.ProcessorDetailsFormControls.BuildPathFormControl.value;
|
|
80
87
|
break;
|
|
81
88
|
case 'NPM':
|
|
82
|
-
app.LowCodeUnit.Package =
|
|
83
|
-
|
|
84
|
-
app.LowCodeUnit.Version =
|
|
85
|
-
this.ProcessorDetailsFormControls.VersionFormControl.value;
|
|
86
|
-
break;
|
|
87
|
-
case 'WordPress':
|
|
88
|
-
app.LowCodeUnit.APIRoot =
|
|
89
|
-
this.ProcessorDetailsFormControls.APIRootFormControl.value;
|
|
89
|
+
app.LowCodeUnit.Package = this.ProcessorDetailsFormControls.PackageFormControl.value;
|
|
90
|
+
app.LowCodeUnit.Version = this.ProcessorDetailsFormControls.VersionFormControl.value;
|
|
90
91
|
break;
|
|
91
92
|
case 'Zip':
|
|
92
|
-
app.LowCodeUnit.ZipFile =
|
|
93
|
-
this.ProcessorDetailsFormControls.ZipFileFormControl.value;
|
|
93
|
+
app.LowCodeUnit.ZipFile = this.ProcessorDetailsFormControls.ZipFileFormControl.value;
|
|
94
94
|
break;
|
|
95
95
|
}
|
|
96
96
|
break;
|
|
97
97
|
case 'OAuth':
|
|
98
|
-
app.Processor.Scopes =
|
|
99
|
-
|
|
100
|
-
app.Processor.TokenLookup =
|
|
101
|
-
this.ProcessorDetailsFormControls.TokenLookupFormControl.value;
|
|
98
|
+
app.Processor.Scopes = this.ProcessorDetailsFormControls.ScopesFormControl.value.split(' ');
|
|
99
|
+
app.Processor.TokenLookup = this.ProcessorDetailsFormControls.TokenLookupFormControl.value;
|
|
102
100
|
app.LowCodeUnit = {
|
|
103
101
|
Type: this.ProcessorDetailsFormControls.LCUType,
|
|
104
102
|
};
|
|
105
103
|
switch (app.LowCodeUnit.Type) {
|
|
106
104
|
case 'GitHubOAuth':
|
|
107
|
-
app.LowCodeUnit.ClientID =
|
|
108
|
-
|
|
109
|
-
app.LowCodeUnit.ClientSecret =
|
|
110
|
-
this.ProcessorDetailsFormControls.ClientSecretFormControl.value;
|
|
105
|
+
app.LowCodeUnit.ClientID = this.ProcessorDetailsFormControls.ClientIDFormControl.value;
|
|
106
|
+
app.LowCodeUnit.ClientSecret = this.ProcessorDetailsFormControls.ClientSecretFormControl.value;
|
|
111
107
|
break;
|
|
112
108
|
}
|
|
113
109
|
break;
|
|
114
110
|
case 'Proxy':
|
|
115
|
-
app.Processor.InboundPath =
|
|
116
|
-
this.ProcessorDetailsFormControls.InboundPathFormControl.value;
|
|
111
|
+
app.Processor.InboundPath = this.ProcessorDetailsFormControls.InboundPathFormControl.value;
|
|
117
112
|
app.LowCodeUnit = {
|
|
118
113
|
Type: this.ProcessorDetailsFormControls.LCUType,
|
|
119
114
|
};
|
|
120
115
|
switch (app.LowCodeUnit.Type) {
|
|
121
116
|
case 'API':
|
|
122
|
-
app.LowCodeUnit.APIRoot =
|
|
123
|
-
|
|
124
|
-
app.LowCodeUnit.Security =
|
|
125
|
-
this.ProcessorDetailsFormControls.SecurityFormControl.value;
|
|
117
|
+
app.LowCodeUnit.APIRoot = this.ProcessorDetailsFormControls.APIRootFormControl.value;
|
|
118
|
+
app.LowCodeUnit.Security = this.ProcessorDetailsFormControls.SecurityFormControl.value;
|
|
126
119
|
break;
|
|
127
120
|
case 'SPA':
|
|
128
|
-
app.LowCodeUnit.SPARoot =
|
|
129
|
-
this.ProcessorDetailsFormControls.SPARootFormControl.value;
|
|
121
|
+
app.LowCodeUnit.SPARoot = this.ProcessorDetailsFormControls.SPARootFormControl.value;
|
|
130
122
|
break;
|
|
131
123
|
}
|
|
132
124
|
break;
|
|
133
125
|
case 'Redirect':
|
|
134
|
-
app.Processor.
|
|
135
|
-
|
|
136
|
-
app.Processor.
|
|
137
|
-
!!this.ProcessorDetailsFormControls.PermanentFormControl.value;
|
|
138
|
-
app.Processor.PreserveMethod =
|
|
139
|
-
!!this.ProcessorDetailsFormControls.PreserveMethodFormControl.value;
|
|
140
|
-
app.Processor.Redirect =
|
|
141
|
-
this.ProcessorDetailsFormControls.RedirectFormControl.value;
|
|
126
|
+
app.Processor.Permanent = !!this.ProcessorDetailsFormControls.PermanentFormControl.value;
|
|
127
|
+
app.Processor.PreserveMethod = !!this.ProcessorDetailsFormControls.PreserveMethodFormControl.value;
|
|
128
|
+
app.Processor.Redirect = this.ProcessorDetailsFormControls.RedirectFormControl.value;
|
|
142
129
|
break;
|
|
143
130
|
}
|
|
144
131
|
if (!app.LookupConfig.PathRegex.startsWith('/')) {
|
|
@@ -149,14 +136,23 @@ export class NewApplicationDialogComponent {
|
|
|
149
136
|
Application: app,
|
|
150
137
|
ApplicationLookup: Guid.CreateRaw(),
|
|
151
138
|
};
|
|
139
|
+
// this.HasBuildFormControl.value && taken out from below if statement
|
|
140
|
+
if (this.ProcessorDetailsFormControls.ProcessorType !== 'redirect') {
|
|
141
|
+
if (app) {
|
|
142
|
+
app.LowCodeUnit.SourceControlLookup = this.ProcessorDetailsFormControls.SourceControlFormControl.value;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
else if (app) {
|
|
146
|
+
app.LowCodeUnit.SourceControlLookup = null;
|
|
147
|
+
}
|
|
152
148
|
this.eacSvc.SaveApplicationAsCode(saveAppReq);
|
|
153
149
|
}
|
|
154
150
|
}
|
|
155
151
|
NewApplicationDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: NewApplicationDialogComponent, deps: [{ token: i1.EaCService }, { token: i2.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
156
|
-
NewApplicationDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: NewApplicationDialogComponent, selector: "lcu-new-application-dialog", viewQueries: [{ propertyName: "ApplicationFormControls", first: true, predicate: EditApplicationFormComponent, descendants: true }, { 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-edit-application-form \n [editing-application]=\"NewApplication\"\n [has-save-button]=\"HasSaveButton\"\n>\n</lcu-edit-application-form>\n\n<lcu-processor-details-form \n [editing-application]=\"NewApplication\"\n [editing-application-lookup]=\"NewApplicationLookup\"\n [has-save-button]=\"HasSaveButton\"\n [source-control-lookups]=\"SourceControlLookups\"\n [project-lookup]=\"data.projectLookup\"\n>\n</lcu-processor-details-form>\n\n<button \n *ngIf=\"ProcessorDetailsFormControls && ApplicationFormControls\"\n mat-raised-button \n color=\"primary\"\n class=\"new-app-submit\" \n (click)=\"SaveApplication()\"\n [disabled]=\"\n !ProcessorDetailsFormControls.ProcessorDetailsFormGroup.valid \n || \n !ApplicationFormControls.ApplicationFormGroup.valid\n \"\n>\n Save Application\n</button>", styles: [".new-app-submit{width:100%}\n"], components: [{ type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.EditApplicationFormComponent, selector: "lcu-edit-application-form", inputs: ["application-lookup", "editing-application", "has-save-button", "project-lookup"], outputs: ["save-form-event"] }, { type: i6.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:
|
|
152
|
+
NewApplicationDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: NewApplicationDialogComponent, selector: "lcu-new-application-dialog", viewQueries: [{ propertyName: "ApplicationFormControls", first: true, predicate: EditApplicationFormComponent, descendants: true }, { 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-edit-application-form \n [editing-application]=\"NewApplication\"\n [has-save-button]=\"HasSaveButton\"\n>\n</lcu-edit-application-form>\n\n<lcu-processor-details-form \n [editing-application]=\"NewApplication\"\n [editing-application-lookup]=\"NewApplicationLookup\"\n [has-save-button]=\"HasSaveButton\"\n [source-control-lookups]=\"SourceControlLookups\"\n [project-lookup]=\"data.projectLookup\"\n>\n</lcu-processor-details-form>\n\n<button \n *ngIf=\"ProcessorDetailsFormControls && ApplicationFormControls && !State?.Loading\"\n mat-raised-button \n color=\"primary\"\n class=\"new-app-submit\" \n (click)=\"SaveApplication()\"\n [disabled]=\"\n !ProcessorDetailsFormControls.ProcessorDetailsFormGroup.valid \n || \n !ApplicationFormControls.ApplicationFormGroup.valid\n \"\n>\n Save Application\n</button>\n<lcu-loader [loading]=\"State?.Loading\"></lcu-loader>", styles: [".new-app-submit{width:100%}\n"], components: [{ type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.EditApplicationFormComponent, selector: "lcu-edit-application-form", inputs: ["application-lookup", "editing-application", "has-save-button", "project-lookup"], outputs: ["save-form-event"] }, { type: i6.ProcessorDetailsFormComponent, selector: "lcu-processor-details-form", inputs: ["editing-application", "editing-application-lookup", "has-save-button", "source-control-lookups", "project-lookup"], outputs: ["save-form-event"] }, { type: i7.LoaderComponent, selector: "lcu-loader", inputs: ["diameter", "hide-inner", "loading"] }], directives: [{ type: i8.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
157
153
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: NewApplicationDialogComponent, decorators: [{
|
|
158
154
|
type: Component,
|
|
159
|
-
args: [{ selector: 'lcu-new-application-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-edit-application-form \n [editing-application]=\"NewApplication\"\n [has-save-button]=\"HasSaveButton\"\n>\n</lcu-edit-application-form>\n\n<lcu-processor-details-form \n [editing-application]=\"NewApplication\"\n [editing-application-lookup]=\"NewApplicationLookup\"\n [has-save-button]=\"HasSaveButton\"\n [source-control-lookups]=\"SourceControlLookups\"\n [project-lookup]=\"data.projectLookup\"\n>\n</lcu-processor-details-form>\n\n<button \n *ngIf=\"ProcessorDetailsFormControls && ApplicationFormControls\"\n mat-raised-button \n color=\"primary\"\n class=\"new-app-submit\" \n (click)=\"SaveApplication()\"\n [disabled]=\"\n !ProcessorDetailsFormControls.ProcessorDetailsFormGroup.valid \n || \n !ApplicationFormControls.ApplicationFormGroup.valid\n \"\n>\n Save Application\n</button>", styles: [".new-app-submit{width:100%}\n"] }]
|
|
155
|
+
args: [{ selector: 'lcu-new-application-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-edit-application-form \n [editing-application]=\"NewApplication\"\n [has-save-button]=\"HasSaveButton\"\n>\n</lcu-edit-application-form>\n\n<lcu-processor-details-form \n [editing-application]=\"NewApplication\"\n [editing-application-lookup]=\"NewApplicationLookup\"\n [has-save-button]=\"HasSaveButton\"\n [source-control-lookups]=\"SourceControlLookups\"\n [project-lookup]=\"data.projectLookup\"\n>\n</lcu-processor-details-form>\n\n<button \n *ngIf=\"ProcessorDetailsFormControls && ApplicationFormControls && !State?.Loading\"\n mat-raised-button \n color=\"primary\"\n class=\"new-app-submit\" \n (click)=\"SaveApplication()\"\n [disabled]=\"\n !ProcessorDetailsFormControls.ProcessorDetailsFormGroup.valid \n || \n !ApplicationFormControls.ApplicationFormGroup.valid\n \"\n>\n Save Application\n</button>\n<lcu-loader [loading]=\"State?.Loading\"></lcu-loader>", styles: [".new-app-submit{width:100%}\n"] }]
|
|
160
156
|
}], ctorParameters: function () { return [{ type: i1.EaCService }, { type: i2.MatDialogRef }, { type: undefined, decorators: [{
|
|
161
157
|
type: Inject,
|
|
162
158
|
args: [MAT_DIALOG_DATA]
|
|
@@ -167,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
167
163
|
type: ViewChild,
|
|
168
164
|
args: [ProcessorDetailsFormComponent]
|
|
169
165
|
}] } });
|
|
170
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"new-application-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/dialogs/new-application-dialog/new-application-dialog.component.ts","../../../../../../projects/common/src/lib/dialogs/new-application-dialog/new-application-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, EnterpriseAsCode } from '@semanticjs/common';\nimport { EditApplicationFormComponent } from '../../controls/edit-application-form/edit-application-form.component';\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\nexport interface NewApplicationDialogData {\n  environmentLookup: string;\n  projectLookup: string;\n}\n\n@Component({\n  selector: 'lcu-new-application-dialog',\n  templateUrl: './new-application-dialog.component.html',\n  styleUrls: ['./new-application-dialog.component.scss']\n})\n\nexport class NewApplicationDialogComponent implements OnInit {\n\n  @ViewChild(EditApplicationFormComponent)\n  public ApplicationFormControls: EditApplicationFormComponent;\n\n  @ViewChild(ProcessorDetailsFormComponent)\n  public ProcessorDetailsFormControls: ProcessorDetailsFormComponent;\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\n  public HasSaveButton: boolean;\n\n  public NewApplication: EaCApplicationAsCode;\n\n  public NewApplicationLookup: string;\n\n\n  constructor(\n    protected eacSvc: EaCService, \n    public dialogRef: MatDialogRef<NewApplicationDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: NewApplicationDialogData) { \n\n    this.HasSaveButton = false\n  }\n\n  public ngOnInit(): void {\n\n    this.SetupApplication(Guid.CreateRaw());\n    \n  }\n\n  public CloseDialog(){\n    this.dialogRef.close();\n  }\n\n  public SetupApplication(appLookup: string){\n    this.NewApplication = new EaCApplicationAsCode;\n    this.NewApplicationLookup = appLookup;\n\n  }\n\n  public SaveApplication(): void {\n\n    const app: EaCApplicationAsCode = new EaCApplicationAsCode;\n\n    app.Application = {\n      Name: this.ApplicationFormControls.NameFormControl.value,\n      Description: this.ApplicationFormControls.DescriptionFormControl.value,\n      PriorityShift: 0,\n    };\n\n    app.LookupConfig.PathRegex = `${this.ApplicationFormControls.RouteFormControl.value}.*`;\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.Processor.BaseHref = `${this.ApplicationFormControls.RouteFormControl.value}/`.replace('//', '/');\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: 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-edit-application-form \n    [editing-application]=\"NewApplication\"\n    [has-save-button]=\"HasSaveButton\"\n>\n</lcu-edit-application-form>\n\n<lcu-processor-details-form \n    [editing-application]=\"NewApplication\"\n    [editing-application-lookup]=\"NewApplicationLookup\"\n    [has-save-button]=\"HasSaveButton\"\n    [source-control-lookups]=\"SourceControlLookups\"\n    [project-lookup]=\"data.projectLookup\"\n>\n</lcu-processor-details-form>\n\n<button \n    *ngIf=\"ProcessorDetailsFormControls && ApplicationFormControls\"\n    mat-raised-button \n    color=\"primary\"\n    class=\"new-app-submit\" \n    (click)=\"SaveApplication()\"\n    [disabled]=\"\n        !ProcessorDetailsFormControls.ProcessorDetailsFormGroup.valid \n        || \n        !ApplicationFormControls.ApplicationFormGroup.valid\n    \"\n>\n    Save Application\n</button>"]}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"new-application-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/dialogs/new-application-dialog/new-application-dialog.component.ts","../../../../../../projects/common/src/lib/dialogs/new-application-dialog/new-application-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, EnterpriseAsCode } from '@semanticjs/common';\nimport { EditApplicationFormComponent } from '../../controls/edit-application-form/edit-application-form.component';\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\nexport interface NewApplicationDialogData {\n  environmentLookup: string;\n  projectLookup: string;\n}\n\n@Component({\n  selector: 'lcu-new-application-dialog',\n  templateUrl: './new-application-dialog.component.html',\n  styleUrls: ['./new-application-dialog.component.scss']\n})\n\nexport class NewApplicationDialogComponent implements OnInit {\n\n  @ViewChild(EditApplicationFormComponent)\n  public ApplicationFormControls: EditApplicationFormComponent;\n\n  @ViewChild(ProcessorDetailsFormComponent)\n  public ProcessorDetailsFormControls: ProcessorDetailsFormComponent;\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\n  public HasSaveButton: boolean;\n\n  public NewApplication: EaCApplicationAsCode;\n\n  public NewApplicationLookup: string;\n\n\n  constructor(\n    protected eacSvc: EaCService, \n    public dialogRef: MatDialogRef<NewApplicationDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: NewApplicationDialogData) { \n\n    this.HasSaveButton = false\n  }\n\n  public ngOnInit(): void {\n\n    this.SetupApplication(Guid.CreateRaw());\n    \n  }\n\n  public CloseDialog(){\n    this.dialogRef.close();\n  }\n\n  public SetupApplication(appLookup: string){\n    this.NewApplication = new EaCApplicationAsCode;\n    this.NewApplicationLookup = appLookup;\n\n  }\n\n  \n\n  public SaveApplication(): void {\n    const app: EaCApplicationAsCode = {\n      Application: {\n        Name: this.ApplicationFormControls.NameFormControl.value,\n        Description: this.ApplicationFormControls.DescriptionFormControl.value,\n        PriorityShift: 0,\n      },\n      AccessRightLookups: [],\n      DataTokens: {},\n      LicenseConfigurationLookups: [],\n      LookupConfig: {\n        IsPrivate: false,\n        IsTriggerSignIn: false,\n        PathRegex: `${this.ApplicationFormControls.RouteFormControl.value}.*`,\n        QueryRegex: '',\n        HeaderRegex: '',\n        AllowedMethods: this.ProcessorDetailsFormControls.MethodsFormControl?.value\n        ?.split(' ')\n        .filter((v: string) => !!v),\n      },\n      Processor: {\n        Type: this.ProcessorDetailsFormControls.ProcessorType,\n      },\n    };\n\n    switch (app.Processor.Type) {\n      case 'DFS':\n        app.Processor.BaseHref = `${this.ApplicationFormControls.RouteFormControl.value}/`.replace(\n          '//',\n          '/'\n        );\n\n        app.Processor.DefaultFile =\n          this.ProcessorDetailsFormControls.DefaultFileFormControl.value || '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 = this.ProcessorDetailsFormControls.BuildFormControl.value;\n\n            app.LowCodeUnit.Path =\n              this.ProcessorDetailsFormControls.BuildPathFormControl.value;\n            break;\n\n          case 'NPM':\n            app.LowCodeUnit.Package = this.ProcessorDetailsFormControls.PackageFormControl.value;\n\n            app.LowCodeUnit.Version = this.ProcessorDetailsFormControls.VersionFormControl.value;\n            break;\n\n          case 'Zip':\n            app.LowCodeUnit.ZipFile = this.ProcessorDetailsFormControls.ZipFileFormControl.value;\n            break;\n        }\n        break;\n\n      case 'OAuth':\n        app.Processor.Scopes = this.ProcessorDetailsFormControls.ScopesFormControl.value.split(' ');\n\n        app.Processor.TokenLookup = 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 = this.ProcessorDetailsFormControls.ClientIDFormControl.value;\n\n            app.LowCodeUnit.ClientSecret = this.ProcessorDetailsFormControls.ClientSecretFormControl.value;\n            break;\n        }\n        break;\n\n      case 'Proxy':\n        app.Processor.InboundPath = 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 = this.ProcessorDetailsFormControls.APIRootFormControl.value;\n\n            app.LowCodeUnit.Security = this.ProcessorDetailsFormControls.SecurityFormControl.value;\n\n            break;\n\n          case 'SPA':\n            app.LowCodeUnit.SPARoot = this.ProcessorDetailsFormControls.SPARootFormControl.value;\n            break;\n        }\n        break;\n\n      case 'Redirect':\n        app.Processor.Permanent = !!this.ProcessorDetailsFormControls.PermanentFormControl.value;\n\n        app.Processor.PreserveMethod = !!this.ProcessorDetailsFormControls.PreserveMethodFormControl.value;\n\n        app.Processor.Redirect = 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: Guid.CreateRaw(),\n    };\n// this.HasBuildFormControl.value &&  taken out from below if statement\n    if (this.ProcessorDetailsFormControls.ProcessorType !== 'redirect') {\n      if (app) {\n        app.LowCodeUnit.SourceControlLookup = this.ProcessorDetailsFormControls.SourceControlFormControl.value;\n      }\n    } else if (app) {\n      app.LowCodeUnit.SourceControlLookup = null;\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-edit-application-form \n    [editing-application]=\"NewApplication\"\n    [has-save-button]=\"HasSaveButton\"\n>\n</lcu-edit-application-form>\n\n<lcu-processor-details-form \n    [editing-application]=\"NewApplication\"\n    [editing-application-lookup]=\"NewApplicationLookup\"\n    [has-save-button]=\"HasSaveButton\"\n    [source-control-lookups]=\"SourceControlLookups\"\n    [project-lookup]=\"data.projectLookup\"\n>\n</lcu-processor-details-form>\n\n<button \n    *ngIf=\"ProcessorDetailsFormControls && ApplicationFormControls && !State?.Loading\"\n    mat-raised-button \n    color=\"primary\"\n    class=\"new-app-submit\" \n    (click)=\"SaveApplication()\"\n    [disabled]=\"\n        !ProcessorDetailsFormControls.ProcessorDetailsFormGroup.valid \n        || \n        !ApplicationFormControls.ApplicationFormGroup.valid\n    \"\n>\n    Save Application\n</button>\n<lcu-loader [loading]=\"State?.Loading\"></lcu-loader>"]}
|
|
@@ -44,10 +44,10 @@ export class ProjectInfoCardComponent {
|
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
46
|
ProjectInfoCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ProjectInfoCardComponent, deps: [{ token: i1.EaCService }, { token: i2.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
47
|
-
ProjectInfoCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: ProjectInfoCardComponent, selector: "lcu-project-info-card", inputs: { Description: ["description", "Description"], Image: ["image", "Image"], IsEditable: ["is-editable", "IsEditable"], IsShareable: ["is-shareable", "IsShareable"], Name: ["name", "Name"], Subtext: ["subtext", "Subtext"] }, outputs: { LeftClickEvent: "left-click-event", RightClickEvent: "right-click-event" }, ngImport: i0, template: "<mat-card class=\"project-info-card\">\n\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\" >\n <skeleton-avatar class=\"round-project-img\" [effect]=\"SkeletonEffect\" [size]=\"75\" ></skeleton-avatar >\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n <mat-card-title \n skeleton-text \n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\" \n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle \n skeleton-text \n [effect]=\"SkeletonEffect\" \n class=\"project-card-description\" \n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div \n skeleton-text \n [effect]=\"SkeletonEffect\" \n class=\"host-anchor\" \n >\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div skeleton-block [effect]=\"SkeletonEffect\" class=\"stats-container\">\n </div>\n\n <div \n class=\"promo-container-skeleton\" \n fxLayout=\"column\" \n fxLayoutAlign=\"center center\" \n >\n \n <div \n skeleton-text \n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">emoji_events</mat-icon>\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" >\n Upgrade to premium now\n </div>\n </div>\n </div>\n\n </mat-card-content>\n <mat-card-actions class=\"actions-container-skeleton\" fxLayoutAlign=\"center center\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" action mat-button >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">outbox</mat-icon>\n Unpack\n </div>\n \n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n<ng-container *ngIf=\"!State?.Loading\">\n\n <div class=\"header-img-container\" fxLayout=\"row\" >\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img *ngIf=\"Image\" [src]=\"Image\" [alt]=\"Name\" style=\"width:75px; height:75px\">\n </div>\n </div>\n\n <div class=\"icon-btn-container\" fxLayout=\"row\" fxLayoutAlign=\"space-between center\" >\n <button *ngIf=\"IsEditable\" mat-icon-button id=\"left-icon\" (click)=\"LeftIconClicked()\">\n <mat-icon>edit</mat-icon>\n </button>\n <button *ngIf=\"IsShareable\" mat-icon-button id=\"right-icon\" (click)=\"RightIconClicked()\">\n <mat-icon>share</mat-icon>\n </button>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">{{Name}}</mat-card-title>\n\n <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">{{Description}}</mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <a class=\"host-anchor\" *ngIf=\"Subtext\" [href]=\"'https://'+Subtext\" target=\"_blank\">{{Subtext}}</a>\n </mat-card-subtitle>\n\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div class=\"stats-container\">\n <ng-content select=\"[stats]\"></ng-content>\n </div>\n\n <!-- <div class=\"promo-container\"> -->\n <!-- <ng-content select=\"[promo]\"></ng-content> -->\n <div class=\"promo-container\" \n fxLayout=\"column\" \n fxLayoutAlign=\"center center\" \n (click)=\"UpgradeClicked()\"\n \n >\n \n <div>Access exclusive tools & insights</div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n <!-- </div> -->\n\n </mat-card-content>\n <mat-card-actions class=\"actions-container\">\n <ng-content select=\"[action]\"></ng-content>\n \n </mat-card-actions>\n </ng-container>\n </mat-card>\n \n", styles: [".project-info-card{margin:20px;padding:0}.round-project-img{background-color:#dfeff2;width:75px;height:75px;border-radius:40px;text-align:center;margin-top:20px;border:2px solid white}.temp-icon{height:50px;width:50px;font-size:50px}.icon-btn-container{margin:5px}.project-card-header{text-align:center;margin-top:50px}.host-anchor{text-decoration:none;color:#4a918e}.header-img-container{background-color:#a4bab3;height:60px;border-radius:2px 2px 0 0;margin-top:-.5px!important;margin-right:-.5px;justify-content:center}.project-card-name{font-size:17px;font-weight:600}.card-content-container{margin-bottom:0!important}.stats-container{border-top:1px solid #b9dddd}.promo-container{cursor:pointer}.gold-icon{color:#d4af37}.upgrade-text{font-weight:700;margin-left:10px;cursor:pointer}mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}.promo-container-skeleton{margin:5px}.actions-container{padding:0!important}.actions-container-skeleton{padding:0!important;border-top:1px solid #b9dddd}.info-card-btn{width:100%;border-radius:0 0 2px 2px;border-top:1px solid #b9dddd}.skeleton-item{margin:5px}\n"], components: [{ type: i3.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i4.SkeletonAvatarComponent, selector: "skeleton-avatar", inputs: ["size", "color", "showIcon", "iconColor", "borderRadius", "effect"] }, { type: i3.MatCardHeader, selector: "mat-card-header" }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i6.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"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.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: i8.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: i3.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { type: i4.SkeletonTextDirective, selector: "[skeleton-text]", inputs: ["effect"] }, { type: i3.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { type: i3.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { type: i3.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }] });
|
|
47
|
+
ProjectInfoCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: ProjectInfoCardComponent, selector: "lcu-project-info-card", inputs: { Description: ["description", "Description"], Image: ["image", "Image"], IsEditable: ["is-editable", "IsEditable"], IsShareable: ["is-shareable", "IsShareable"], Name: ["name", "Name"], Subtext: ["subtext", "Subtext"], Version: ["version", "Version"] }, outputs: { LeftClickEvent: "left-click-event", RightClickEvent: "right-click-event" }, ngImport: i0, template: "<mat-card class=\"project-info-card\">\n\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\" >\n <skeleton-avatar class=\"round-project-img\" [effect]=\"SkeletonEffect\" [size]=\"75\" ></skeleton-avatar >\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n <mat-card-title \n skeleton-text \n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\" \n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle \n skeleton-text \n [effect]=\"SkeletonEffect\" \n class=\"project-card-description\" \n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div \n skeleton-text \n [effect]=\"SkeletonEffect\" \n class=\"host-anchor\" \n >\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div skeleton-block [effect]=\"SkeletonEffect\" class=\"stats-container\">\n </div>\n\n <div \n class=\"promo-container-skeleton\" \n fxLayout=\"column\" \n fxLayoutAlign=\"center center\" \n >\n \n <div \n skeleton-text \n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">emoji_events</mat-icon>\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" >\n Upgrade to premium now\n </div>\n </div>\n </div>\n\n </mat-card-content>\n <mat-card-actions class=\"actions-container-skeleton\" fxLayoutAlign=\"center center\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" action mat-button >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">outbox</mat-icon>\n Unpack\n </div>\n \n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n<ng-container *ngIf=\"!State?.Loading\">\n\n <div class=\"header-img-container\" fxLayout=\"row\" >\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img *ngIf=\"Image\" [src]=\"Image\" [alt]=\"Name\" style=\"width:75px; height:75px\">\n </div>\n </div>\n\n <div class=\"icon-btn-container\" fxLayout=\"row\" fxLayoutAlign=\"space-between center\" >\n <button *ngIf=\"IsEditable\" mat-icon-button id=\"left-icon\" (click)=\"LeftIconClicked()\">\n <mat-icon>edit</mat-icon>\n </button>\n <button *ngIf=\"IsShareable\" mat-icon-button id=\"right-icon\" (click)=\"RightIconClicked()\">\n <mat-icon>share</mat-icon>\n </button>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">{{Name}}</mat-card-title>\n\n <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">{{Description}}</mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-version\" *ngIf=\"Version\">Current Version: {{Version}}</mat-card-subtitle>\n\n\n <mat-card-subtitle class=\"project-card-host\">\n <a class=\"host-anchor\" *ngIf=\"Subtext\" [href]=\"'https://'+Subtext\" target=\"_blank\">{{Subtext}}</a>\n </mat-card-subtitle>\n\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div class=\"stats-container\">\n <ng-content select=\"[stats]\"></ng-content>\n </div>\n\n <!-- <div class=\"promo-container\"> -->\n <!-- <ng-content select=\"[promo]\"></ng-content> -->\n <div class=\"promo-container\" \n fxLayout=\"column\" \n fxLayoutAlign=\"center center\" \n (click)=\"UpgradeClicked()\"\n \n >\n \n <div>Access exclusive tools & insights</div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n <!-- </div> -->\n\n </mat-card-content>\n <mat-card-actions class=\"actions-container\">\n <ng-content select=\"[action]\"></ng-content>\n \n </mat-card-actions>\n </ng-container>\n </mat-card>\n \n", styles: [".project-info-card{margin:20px;padding:0}.round-project-img{background-color:#dfeff2;width:75px;height:75px;border-radius:40px;text-align:center;margin-top:20px;border:2px solid white}.temp-icon{height:50px;width:50px;font-size:50px}.icon-btn-container{margin:5px}.project-card-header{text-align:center;margin-top:50px}.host-anchor{text-decoration:none;color:#4a918e}.header-img-container{background-color:#a4bab3;height:60px;border-radius:2px 2px 0 0;margin-top:-.5px!important;margin-right:-.5px;justify-content:center}.project-card-name{font-size:17px;font-weight:600}.card-content-container{margin-bottom:0!important}.stats-container{border-top:1px solid #b9dddd}.promo-container{cursor:pointer}.gold-icon{color:#d4af37}.upgrade-text{font-weight:700;margin-left:10px;cursor:pointer}mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}.promo-container-skeleton{margin:5px}.actions-container{padding:0!important}.actions-container-skeleton{padding:0!important;border-top:1px solid #b9dddd}.info-card-btn{width:100%;border-radius:0 0 2px 2px;border-top:1px solid #b9dddd}.skeleton-item{margin:5px}\n"], components: [{ type: i3.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i4.SkeletonAvatarComponent, selector: "skeleton-avatar", inputs: ["size", "color", "showIcon", "iconColor", "borderRadius", "effect"] }, { type: i3.MatCardHeader, selector: "mat-card-header" }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i6.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"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.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: i8.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: i3.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { type: i4.SkeletonTextDirective, selector: "[skeleton-text]", inputs: ["effect"] }, { type: i3.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { type: i3.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { type: i3.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }] });
|
|
48
48
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ProjectInfoCardComponent, decorators: [{
|
|
49
49
|
type: Component,
|
|
50
|
-
args: [{ selector: 'lcu-project-info-card', template: "<mat-card class=\"project-info-card\">\n\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\" >\n <skeleton-avatar class=\"round-project-img\" [effect]=\"SkeletonEffect\" [size]=\"75\" ></skeleton-avatar >\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n <mat-card-title \n skeleton-text \n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\" \n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle \n skeleton-text \n [effect]=\"SkeletonEffect\" \n class=\"project-card-description\" \n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div \n skeleton-text \n [effect]=\"SkeletonEffect\" \n class=\"host-anchor\" \n >\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div skeleton-block [effect]=\"SkeletonEffect\" class=\"stats-container\">\n </div>\n\n <div \n class=\"promo-container-skeleton\" \n fxLayout=\"column\" \n fxLayoutAlign=\"center center\" \n >\n \n <div \n skeleton-text \n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">emoji_events</mat-icon>\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" >\n Upgrade to premium now\n </div>\n </div>\n </div>\n\n </mat-card-content>\n <mat-card-actions class=\"actions-container-skeleton\" fxLayoutAlign=\"center center\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" action mat-button >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">outbox</mat-icon>\n Unpack\n </div>\n \n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n<ng-container *ngIf=\"!State?.Loading\">\n\n <div class=\"header-img-container\" fxLayout=\"row\" >\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img *ngIf=\"Image\" [src]=\"Image\" [alt]=\"Name\" style=\"width:75px; height:75px\">\n </div>\n </div>\n\n <div class=\"icon-btn-container\" fxLayout=\"row\" fxLayoutAlign=\"space-between center\" >\n <button *ngIf=\"IsEditable\" mat-icon-button id=\"left-icon\" (click)=\"LeftIconClicked()\">\n <mat-icon>edit</mat-icon>\n </button>\n <button *ngIf=\"IsShareable\" mat-icon-button id=\"right-icon\" (click)=\"RightIconClicked()\">\n <mat-icon>share</mat-icon>\n </button>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">{{Name}}</mat-card-title>\n\n <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">{{Description}}</mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <a class=\"host-anchor\" *ngIf=\"Subtext\" [href]=\"'https://'+Subtext\" target=\"_blank\">{{Subtext}}</a>\n </mat-card-subtitle>\n\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div class=\"stats-container\">\n <ng-content select=\"[stats]\"></ng-content>\n </div>\n\n <!-- <div class=\"promo-container\"> -->\n <!-- <ng-content select=\"[promo]\"></ng-content> -->\n <div class=\"promo-container\" \n fxLayout=\"column\" \n fxLayoutAlign=\"center center\" \n (click)=\"UpgradeClicked()\"\n \n >\n \n <div>Access exclusive tools & insights</div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n <!-- </div> -->\n\n </mat-card-content>\n <mat-card-actions class=\"actions-container\">\n <ng-content select=\"[action]\"></ng-content>\n \n </mat-card-actions>\n </ng-container>\n </mat-card>\n \n", styles: [".project-info-card{margin:20px;padding:0}.round-project-img{background-color:#dfeff2;width:75px;height:75px;border-radius:40px;text-align:center;margin-top:20px;border:2px solid white}.temp-icon{height:50px;width:50px;font-size:50px}.icon-btn-container{margin:5px}.project-card-header{text-align:center;margin-top:50px}.host-anchor{text-decoration:none;color:#4a918e}.header-img-container{background-color:#a4bab3;height:60px;border-radius:2px 2px 0 0;margin-top:-.5px!important;margin-right:-.5px;justify-content:center}.project-card-name{font-size:17px;font-weight:600}.card-content-container{margin-bottom:0!important}.stats-container{border-top:1px solid #b9dddd}.promo-container{cursor:pointer}.gold-icon{color:#d4af37}.upgrade-text{font-weight:700;margin-left:10px;cursor:pointer}mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}.promo-container-skeleton{margin:5px}.actions-container{padding:0!important}.actions-container-skeleton{padding:0!important;border-top:1px solid #b9dddd}.info-card-btn{width:100%;border-radius:0 0 2px 2px;border-top:1px solid #b9dddd}.skeleton-item{margin:5px}\n"] }]
|
|
50
|
+
args: [{ selector: 'lcu-project-info-card', template: "<mat-card class=\"project-info-card\">\n\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\" >\n <skeleton-avatar class=\"round-project-img\" [effect]=\"SkeletonEffect\" [size]=\"75\" ></skeleton-avatar >\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n <mat-card-title \n skeleton-text \n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\" \n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle \n skeleton-text \n [effect]=\"SkeletonEffect\" \n class=\"project-card-description\" \n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div \n skeleton-text \n [effect]=\"SkeletonEffect\" \n class=\"host-anchor\" \n >\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div skeleton-block [effect]=\"SkeletonEffect\" class=\"stats-container\">\n </div>\n\n <div \n class=\"promo-container-skeleton\" \n fxLayout=\"column\" \n fxLayoutAlign=\"center center\" \n >\n \n <div \n skeleton-text \n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">emoji_events</mat-icon>\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" >\n Upgrade to premium now\n </div>\n </div>\n </div>\n\n </mat-card-content>\n <mat-card-actions class=\"actions-container-skeleton\" fxLayoutAlign=\"center center\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" action mat-button >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">outbox</mat-icon>\n Unpack\n </div>\n \n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n<ng-container *ngIf=\"!State?.Loading\">\n\n <div class=\"header-img-container\" fxLayout=\"row\" >\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img *ngIf=\"Image\" [src]=\"Image\" [alt]=\"Name\" style=\"width:75px; height:75px\">\n </div>\n </div>\n\n <div class=\"icon-btn-container\" fxLayout=\"row\" fxLayoutAlign=\"space-between center\" >\n <button *ngIf=\"IsEditable\" mat-icon-button id=\"left-icon\" (click)=\"LeftIconClicked()\">\n <mat-icon>edit</mat-icon>\n </button>\n <button *ngIf=\"IsShareable\" mat-icon-button id=\"right-icon\" (click)=\"RightIconClicked()\">\n <mat-icon>share</mat-icon>\n </button>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">{{Name}}</mat-card-title>\n\n <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">{{Description}}</mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-version\" *ngIf=\"Version\">Current Version: {{Version}}</mat-card-subtitle>\n\n\n <mat-card-subtitle class=\"project-card-host\">\n <a class=\"host-anchor\" *ngIf=\"Subtext\" [href]=\"'https://'+Subtext\" target=\"_blank\">{{Subtext}}</a>\n </mat-card-subtitle>\n\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div class=\"stats-container\">\n <ng-content select=\"[stats]\"></ng-content>\n </div>\n\n <!-- <div class=\"promo-container\"> -->\n <!-- <ng-content select=\"[promo]\"></ng-content> -->\n <div class=\"promo-container\" \n fxLayout=\"column\" \n fxLayoutAlign=\"center center\" \n (click)=\"UpgradeClicked()\"\n \n >\n \n <div>Access exclusive tools & insights</div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n <!-- </div> -->\n\n </mat-card-content>\n <mat-card-actions class=\"actions-container\">\n <ng-content select=\"[action]\"></ng-content>\n \n </mat-card-actions>\n </ng-container>\n </mat-card>\n \n", styles: [".project-info-card{margin:20px;padding:0}.round-project-img{background-color:#dfeff2;width:75px;height:75px;border-radius:40px;text-align:center;margin-top:20px;border:2px solid white}.temp-icon{height:50px;width:50px;font-size:50px}.icon-btn-container{margin:5px}.project-card-header{text-align:center;margin-top:50px}.host-anchor{text-decoration:none;color:#4a918e}.header-img-container{background-color:#a4bab3;height:60px;border-radius:2px 2px 0 0;margin-top:-.5px!important;margin-right:-.5px;justify-content:center}.project-card-name{font-size:17px;font-weight:600}.card-content-container{margin-bottom:0!important}.stats-container{border-top:1px solid #b9dddd}.promo-container{cursor:pointer}.gold-icon{color:#d4af37}.upgrade-text{font-weight:700;margin-left:10px;cursor:pointer}mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}.promo-container-skeleton{margin:5px}.actions-container{padding:0!important}.actions-container-skeleton{padding:0!important;border-top:1px solid #b9dddd}.info-card-btn{width:100%;border-radius:0 0 2px 2px;border-top:1px solid #b9dddd}.skeleton-item{margin:5px}\n"] }]
|
|
51
51
|
}], ctorParameters: function () { return [{ type: i1.EaCService }, { type: i2.MatDialog }]; }, propDecorators: { Description: [{
|
|
52
52
|
type: Input,
|
|
53
53
|
args: ['description']
|
|
@@ -66,6 +66,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
66
66
|
}], Subtext: [{
|
|
67
67
|
type: Input,
|
|
68
68
|
args: ['subtext']
|
|
69
|
+
}], Version: [{
|
|
70
|
+
type: Input,
|
|
71
|
+
args: ['version']
|
|
69
72
|
}], LeftClickEvent: [{
|
|
70
73
|
type: Output,
|
|
71
74
|
args: ['left-click-event']
|
|
@@ -73,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
73
76
|
type: Output,
|
|
74
77
|
args: ['right-click-event']
|
|
75
78
|
}] } });
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"project-info-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/project-info-card/project-info-card.component.ts","../../../../../../projects/common/src/lib/elements/project-info-card/project-info-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,sBAAsB,EAAE,MAAM,uDAAuD,CAAC;;;;;;;;;;AAS/F,MAAM,OAAO,wBAAwB;IAiCnC,YAAsB,MAAkB,EAAW,MAAiB;QAA9C,WAAM,GAAN,MAAM,CAAY;QAAW,WAAM,GAAN,MAAM,CAAW;QAClE,IAAI,CAAC,cAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QAEzC,IAAI,CAAC,eAAe,GAAG,IAAI,YAAY,EAAE,CAAC;QAE1C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;IAC9B,CAAC;IAbF,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;IAC3B,CAAC;IAaM,QAAQ;QACb,0CAA0C;QAC1C,mDAAmD;QACnD,iDAAiD;IACnD,CAAC;IAIM,eAAe;QACpB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;IAEM,gBAAgB;QACrB,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAA;QAC5B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;IAEM,cAAc;QACnB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;YACzD,KAAK,EAAE,OAAO;YACd,IAAI,EAAE,EACL;SACF,CAAC,CAAC;QAEH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3C,wCAAwC;YACxC,iCAAiC;QACnC,CAAC,CAAC,CAAC;IAEL,CAAC;;qHAtEU,wBAAwB;yGAAxB,wBAAwB,0XCXrC,+hJA4IA;2FDjIa,wBAAwB;kBALpC,SAAS;+BACE,uBAAuB;yHAO1B,WAAW;sBADjB,KAAK;uBAAC,aAAa;gBAIb,KAAK;sBADX,KAAK;uBAAC,OAAO;gBAIP,UAAU;sBADhB,KAAK;uBAAC,aAAa;gBAIb,WAAW;sBADjB,KAAK;uBAAC,cAAc;gBAId,IAAI;sBADV,KAAK;uBAAC,MAAM;gBAIN,OAAO;sBADb,KAAK;uBAAC,SAAS;gBAIT,cAAc;sBADpB,MAAM;uBAAC,kBAAkB;gBAInB,eAAe;sBADrB,MAAM;uBAAC,mBAAmB","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { UpgradeDialogComponent } from '../../dialogs/upgrade-dialog/upgrade-dialog.component';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-project-info-card',\n  templateUrl: './project-info-card.component.html',\n  styleUrls: ['./project-info-card.component.scss']\n})\nexport class ProjectInfoCardComponent implements OnInit {\n  \n  @Input('description')\n  public Description: string;\n  \n  @Input('image')\n  public Image: string;\n\n  @Input('is-editable')\n  public IsEditable: boolean;\n\n  @Input('is-shareable')\n  public IsShareable: boolean;\n\n  @Input('name')\n  public Name: string;\n\n  @Input('subtext')\n  public Subtext: string;\n\n  @Output('left-click-event')\n  public LeftClickEvent: EventEmitter<{}>;\n\n  @Output('right-click-event')\n  public RightClickEvent: EventEmitter<{}>;\n\n  public get State(): ApplicationsFlowState{\n    return this.eacSvc.State;\n  }\n\n  public SkeletonEffect: string;\n\n\n  constructor(protected eacSvc: EaCService,protected dialog: MatDialog,) {\n    this.LeftClickEvent = new EventEmitter();\n\n    this.RightClickEvent = new EventEmitter();\n\n    this.SkeletonEffect = 'wave';\n   }\n\n  public ngOnInit(): void {\n    // console.log(\"loading = \", this.Loading)\n    // console.log(\"is shareable: \", this.IsShareable);\n    // console.log(\"is editable: \", this.IsEditable);\n  }\n\n\n\n  public LeftIconClicked(){\n    this.LeftClickEvent.emit({});\n  }\n\n  public RightIconClicked(){\n    console.log(\"share clicked\")\n    this.RightClickEvent.emit({});\n  }\n\n  public UpgradeClicked(){\n    const dialogRef = this.dialog.open(UpgradeDialogComponent, {\n      width: '600px',\n      data: {\n      },\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      // console.log('The dialog was closed');\n      // console.log(\"result:\", result)\n    });\n\n  }\n\n}\n","<mat-card class=\"project-info-card\">\n\n  <!-- SKELETON CONTENT -->\n  <ng-container *ngIf=\"State?.Loading\">\n    <div class=\"header-img-container\" fxLayout=\"row\" >\n      <skeleton-avatar class=\"round-project-img\" [effect]=\"SkeletonEffect\" [size]=\"75\" ></skeleton-avatar >\n  </div>\n\n  <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n    <mat-card-title \n      skeleton-text  \n      [effect]=\"SkeletonEffect\"\n      class=\"project-card-name\" \n    >\n      Name of card\n    </mat-card-title>\n\n    <mat-card-subtitle \n      skeleton-text \n      [effect]=\"SkeletonEffect\" \n      class=\"project-card-description\" \n    >\n      Description Text\n    </mat-card-subtitle>\n\n    <mat-card-subtitle class=\"project-card-host\">\n        <div \n          skeleton-text \n          [effect]=\"SkeletonEffect\" \n          class=\"host-anchor\" \n        >\n          https://www.fathym.com\n        </div>\n    </mat-card-subtitle>\n\n  </mat-card-header>\n  <mat-card-content class=\"card-content-container\">\n    <div skeleton-block [effect]=\"SkeletonEffect\" class=\"stats-container\">\n    </div>\n\n    <div \n      class=\"promo-container-skeleton\" \n      fxLayout=\"column\" \n      fxLayoutAlign=\"center center\" \n    >\n        \n      <div \n        skeleton-text \n        [effect]=\"SkeletonEffect\"\n        class=\"skeleton-item\"\n      >\n        Access exclusive tools & insights\n      </div>\n\n      <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n        <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">emoji_events</mat-icon>\n\n        <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" >\n          Upgrade to premium now\n        </div>\n      </div>\n    </div>\n\n  </mat-card-content>\n  <mat-card-actions class=\"actions-container-skeleton\" fxLayoutAlign=\"center center\">\n    <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" action mat-button >\n      <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">outbox</mat-icon>\n      Unpack\n    </div>\n    \n  </mat-card-actions>\n  </ng-container>\n  <!-- END SKELETON CONTENT -->\n\n  <!-- ACTUAL CONTENT -->\n\n<ng-container *ngIf=\"!State?.Loading\">\n\n    <div class=\"header-img-container\" fxLayout=\"row\" >\n        <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n            <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n            <img *ngIf=\"Image\" [src]=\"Image\" [alt]=\"Name\" style=\"width:75px; height:75px\">\n        </div>\n    </div>\n\n    <div class=\"icon-btn-container\" fxLayout=\"row\" fxLayoutAlign=\"space-between center\" >\n      <button *ngIf=\"IsEditable\" mat-icon-button id=\"left-icon\" (click)=\"LeftIconClicked()\">\n        <mat-icon>edit</mat-icon>\n      </button>\n      <button *ngIf=\"IsShareable\" mat-icon-button id=\"right-icon\" (click)=\"RightIconClicked()\">\n        <mat-icon>share</mat-icon>\n      </button>\n    </div>\n\n    <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n      <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">{{Name}}</mat-card-title>\n\n      <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">{{Description}}</mat-card-subtitle>\n\n      <mat-card-subtitle class=\"project-card-host\">\n          <a class=\"host-anchor\" *ngIf=\"Subtext\" [href]=\"'https://'+Subtext\" target=\"_blank\">{{Subtext}}</a>\n      </mat-card-subtitle>\n\n    </mat-card-header>\n    <mat-card-content class=\"card-content-container\">\n      <div class=\"stats-container\">\n        <ng-content  select=\"[stats]\"></ng-content>\n      </div>\n\n      <!-- <div class=\"promo-container\"> -->\n        <!-- <ng-content  select=\"[promo]\"></ng-content> -->\n        <div class=\"promo-container\" \n          fxLayout=\"column\" \n          fxLayoutAlign=\"center center\" \n          (click)=\"UpgradeClicked()\"\n          \n        >\n        \n        <div>Access exclusive tools & insights</div>\n\n        <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n          <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n          <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n            Upgrade to premium now\n          </div>\n        </div>\n      </div>\n      <!-- </div> -->\n\n    </mat-card-content>\n    <mat-card-actions class=\"actions-container\">\n      <ng-content select=\"[action]\"></ng-content>\n      \n    </mat-card-actions>\n  </ng-container>\n  </mat-card>\n  \n"]}
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"project-info-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/project-info-card/project-info-card.component.ts","../../../../../../projects/common/src/lib/elements/project-info-card/project-info-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,sBAAsB,EAAE,MAAM,uDAAuD,CAAC;;;;;;;;;;AAS/F,MAAM,OAAO,wBAAwB;IAoCnC,YAAsB,MAAkB,EAAW,MAAiB;QAA9C,WAAM,GAAN,MAAM,CAAY;QAAW,WAAM,GAAN,MAAM,CAAW;QAClE,IAAI,CAAC,cAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QAEzC,IAAI,CAAC,eAAe,GAAG,IAAI,YAAY,EAAE,CAAC;QAE1C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;IAC9B,CAAC;IAbF,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;IAC3B,CAAC;IAaM,QAAQ;QACb,0CAA0C;QAC1C,mDAAmD;QACnD,iDAAiD;IACnD,CAAC;IAIM,eAAe;QACpB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;IAEM,gBAAgB;QACrB,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAA;QAC5B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;IAEM,cAAc;QACnB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;YACzD,KAAK,EAAE,OAAO;YACd,IAAI,EAAE,EACL;SACF,CAAC,CAAC;QAEH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3C,wCAAwC;YACxC,iCAAiC;QACnC,CAAC,CAAC,CAAC;IAEL,CAAC;;qHAzEU,wBAAwB;yGAAxB,wBAAwB,2ZCXrC,+pJA+IA;2FDpIa,wBAAwB;kBALpC,SAAS;+BACE,uBAAuB;yHAO1B,WAAW;sBADjB,KAAK;uBAAC,aAAa;gBAIb,KAAK;sBADX,KAAK;uBAAC,OAAO;gBAIP,UAAU;sBADhB,KAAK;uBAAC,aAAa;gBAIb,WAAW;sBADjB,KAAK;uBAAC,cAAc;gBAId,IAAI;sBADV,KAAK;uBAAC,MAAM;gBAIN,OAAO;sBADb,KAAK;uBAAC,SAAS;gBAIT,OAAO;sBADb,KAAK;uBAAC,SAAS;gBAIT,cAAc;sBADpB,MAAM;uBAAC,kBAAkB;gBAInB,eAAe;sBADrB,MAAM;uBAAC,mBAAmB","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { UpgradeDialogComponent } from '../../dialogs/upgrade-dialog/upgrade-dialog.component';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-project-info-card',\n  templateUrl: './project-info-card.component.html',\n  styleUrls: ['./project-info-card.component.scss']\n})\nexport class ProjectInfoCardComponent implements OnInit {\n  \n  @Input('description')\n  public Description: string;\n  \n  @Input('image')\n  public Image: string;\n\n  @Input('is-editable')\n  public IsEditable: boolean;\n\n  @Input('is-shareable')\n  public IsShareable: boolean;\n\n  @Input('name')\n  public Name: string;\n\n  @Input('subtext')\n  public Subtext: string;\n\n  @Input('version')\n  public Version: string;\n\n  @Output('left-click-event')\n  public LeftClickEvent: EventEmitter<{}>;\n\n  @Output('right-click-event')\n  public RightClickEvent: EventEmitter<{}>;\n\n  public get State(): ApplicationsFlowState{\n    return this.eacSvc.State;\n  }\n\n  public SkeletonEffect: string;\n\n\n  constructor(protected eacSvc: EaCService,protected dialog: MatDialog,) {\n    this.LeftClickEvent = new EventEmitter();\n\n    this.RightClickEvent = new EventEmitter();\n\n    this.SkeletonEffect = 'wave';\n   }\n\n  public ngOnInit(): void {\n    // console.log(\"loading = \", this.Loading)\n    // console.log(\"is shareable: \", this.IsShareable);\n    // console.log(\"is editable: \", this.IsEditable);\n  }\n\n\n\n  public LeftIconClicked(){\n    this.LeftClickEvent.emit({});\n  }\n\n  public RightIconClicked(){\n    console.log(\"share clicked\")\n    this.RightClickEvent.emit({});\n  }\n\n  public UpgradeClicked(){\n    const dialogRef = this.dialog.open(UpgradeDialogComponent, {\n      width: '600px',\n      data: {\n      },\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      // console.log('The dialog was closed');\n      // console.log(\"result:\", result)\n    });\n\n  }\n\n}\n","<mat-card class=\"project-info-card\">\n\n  <!-- SKELETON CONTENT -->\n  <ng-container *ngIf=\"State?.Loading\">\n    <div class=\"header-img-container\" fxLayout=\"row\" >\n      <skeleton-avatar class=\"round-project-img\" [effect]=\"SkeletonEffect\" [size]=\"75\" ></skeleton-avatar >\n  </div>\n\n  <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n    <mat-card-title \n      skeleton-text  \n      [effect]=\"SkeletonEffect\"\n      class=\"project-card-name\" \n    >\n      Name of card\n    </mat-card-title>\n\n    <mat-card-subtitle \n      skeleton-text \n      [effect]=\"SkeletonEffect\" \n      class=\"project-card-description\" \n    >\n      Description Text\n    </mat-card-subtitle>\n\n    <mat-card-subtitle class=\"project-card-host\">\n        <div \n          skeleton-text \n          [effect]=\"SkeletonEffect\" \n          class=\"host-anchor\" \n        >\n          https://www.fathym.com\n        </div>\n    </mat-card-subtitle>\n\n  </mat-card-header>\n  <mat-card-content class=\"card-content-container\">\n    <div skeleton-block [effect]=\"SkeletonEffect\" class=\"stats-container\">\n    </div>\n\n    <div \n      class=\"promo-container-skeleton\" \n      fxLayout=\"column\" \n      fxLayoutAlign=\"center center\" \n    >\n        \n      <div \n        skeleton-text \n        [effect]=\"SkeletonEffect\"\n        class=\"skeleton-item\"\n      >\n        Access exclusive tools & insights\n      </div>\n\n      <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n        <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">emoji_events</mat-icon>\n\n        <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" >\n          Upgrade to premium now\n        </div>\n      </div>\n    </div>\n\n  </mat-card-content>\n  <mat-card-actions class=\"actions-container-skeleton\" fxLayoutAlign=\"center center\">\n    <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\" action mat-button >\n      <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">outbox</mat-icon>\n      Unpack\n    </div>\n    \n  </mat-card-actions>\n  </ng-container>\n  <!-- END SKELETON CONTENT -->\n\n  <!-- ACTUAL CONTENT -->\n\n<ng-container *ngIf=\"!State?.Loading\">\n\n    <div class=\"header-img-container\" fxLayout=\"row\" >\n        <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n            <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n            <img *ngIf=\"Image\" [src]=\"Image\" [alt]=\"Name\" style=\"width:75px; height:75px\">\n        </div>\n    </div>\n\n    <div class=\"icon-btn-container\" fxLayout=\"row\" fxLayoutAlign=\"space-between center\" >\n      <button *ngIf=\"IsEditable\" mat-icon-button id=\"left-icon\" (click)=\"LeftIconClicked()\">\n        <mat-icon>edit</mat-icon>\n      </button>\n      <button *ngIf=\"IsShareable\" mat-icon-button id=\"right-icon\" (click)=\"RightIconClicked()\">\n        <mat-icon>share</mat-icon>\n      </button>\n    </div>\n\n    <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n\n      <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">{{Name}}</mat-card-title>\n\n      <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">{{Description}}</mat-card-subtitle>\n\n      <mat-card-subtitle class=\"project-card-version\" *ngIf=\"Version\">Current Version: {{Version}}</mat-card-subtitle>\n\n\n      <mat-card-subtitle class=\"project-card-host\">\n          <a class=\"host-anchor\" *ngIf=\"Subtext\" [href]=\"'https://'+Subtext\" target=\"_blank\">{{Subtext}}</a>\n      </mat-card-subtitle>\n\n    </mat-card-header>\n    <mat-card-content class=\"card-content-container\">\n      <div class=\"stats-container\">\n        <ng-content  select=\"[stats]\"></ng-content>\n      </div>\n\n      <!-- <div class=\"promo-container\"> -->\n        <!-- <ng-content  select=\"[promo]\"></ng-content> -->\n        <div class=\"promo-container\" \n          fxLayout=\"column\" \n          fxLayoutAlign=\"center center\" \n          (click)=\"UpgradeClicked()\"\n          \n        >\n        \n        <div>Access exclusive tools & insights</div>\n\n        <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n          <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n          <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n            Upgrade to premium now\n          </div>\n        </div>\n      </div>\n      <!-- </div> -->\n\n    </mat-card-content>\n    <mat-card-actions class=\"actions-container\">\n      <ng-content select=\"[action]\"></ng-content>\n      \n    </mat-card-actions>\n  </ng-container>\n  </mat-card>\n  \n"]}
|