@lowcodeunit/applications-flow-common 1.37.80-new-state-setup → 1.37.85-mobile-friendly

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.
Files changed (26) hide show
  1. package/esm2020/lib/controls/build-pipeline-form/build-pipeline-form.component.mjs +2 -2
  2. package/esm2020/lib/controls/devops-source-control-form/devops-source-control-form.component.mjs +12 -10
  3. package/esm2020/lib/dialogs/build-pipeline-dialog/build-pipeline-dialog.component.mjs +3 -3
  4. package/esm2020/lib/dialogs/edit-application-dialog/edit-application-dialog.component.mjs +3 -3
  5. package/esm2020/lib/dialogs/edit-project-dialog/edit-project-dialog.component.mjs +3 -3
  6. package/esm2020/lib/dialogs/feed-header-dialog/feed-header-dialog.component.mjs +8 -8
  7. package/esm2020/lib/dialogs/new-application-dialog/new-application-dialog.component.mjs +3 -3
  8. package/esm2020/lib/dialogs/processor-details-dialog/processor-details-dialog.component.mjs +3 -3
  9. package/esm2020/lib/dialogs/source-control-dialog/source-control-dialog.component.mjs +1 -1
  10. package/esm2020/lib/dialogs/state-config-dialog/state-config-dialog.component.mjs +3 -3
  11. package/esm2020/lib/elements/activity-card/activity-card.component.mjs +3 -3
  12. package/esm2020/lib/elements/breadcrumb/breadcrumb.component.mjs +6 -2
  13. package/esm2020/lib/elements/feed-header/feed-header.component.mjs +6 -4
  14. package/esm2020/lib/elements/main-feed-card/main-feed-card.component.mjs +4 -4
  15. package/esm2020/lib/elements/project-card/project-card.component.mjs +164 -18
  16. package/esm2020/lib/elements/project-wizard-card/project-wizard-card.component.mjs +5 -13
  17. package/esm2020/lib/models/tree-node.model.mjs +5 -0
  18. package/esm2020/lib/services/social-ui.service.mjs +3 -1
  19. package/fesm2015/lowcodeunit-applications-flow-common.mjs +268 -103
  20. package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
  21. package/fesm2020/lowcodeunit-applications-flow-common.mjs +244 -89
  22. package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
  23. package/lib/elements/feed-header/feed-header.component.d.ts +1 -0
  24. package/lib/elements/project-card/project-card.component.d.ts +45 -3
  25. package/lib/models/tree-node.model.d.ts +17 -0
  26. package/package.json +1 -1
@@ -43,15 +43,15 @@ export class MainFeedCardComponent {
43
43
  this.SanitizeVideos();
44
44
  }
45
45
  ngOnChanges() {
46
- if (this.FeedItem.Status.Code === 0) {
46
+ if (this.FeedItem?.Status?.Code === 0) {
47
47
  this.Icon = 'check_circle';
48
48
  this.IconColor = 'green';
49
49
  }
50
- else if (this.FeedItem.Status.Code === 1) {
50
+ else if (this.FeedItem?.Status?.Code === 1) {
51
51
  this.Icon = 'cancel';
52
52
  this.IconColor = 'red';
53
53
  }
54
- else if (this.FeedItem.Status.Code === 2) {
54
+ else if (this.FeedItem?.Status?.Code === 2) {
55
55
  this.Icon = 'sync';
56
56
  this.IconColor = 'blue';
57
57
  }
@@ -153,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
153
153
  type: Input,
154
154
  args: ['feed-item']
155
155
  }] } });
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main-feed-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/main-feed-card/main-feed-card.component.ts","../../../../../../projects/common/src/lib/elements/main-feed-card/main-feed-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, OnDestroy, ViewChild } from '@angular/core';\nimport { FeedItem, FeedItemAction } from '../../models/user-feed.model';\nimport moment from 'moment';\nimport { EaCService } from '../../services/eac.service';\nimport { BaseModeledResponse } from '@lcu/common';\nimport { SourceControlDialogComponent } from '../../dialogs/source-control-dialog/source-control-dialog.component';\nimport { MatDialog } from '@angular/material/dialog';\nimport { EaCEnvironmentAsCode } from '@semanticjs/common';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { AbstractControl, FormBuilder } from '@angular/forms';\nimport { FeedCommentFormComponent } from '../../controls/feed-comment-form/feed-comment-form.component';\n\n@Component({\n    selector: 'lcu-main-feed-card',\n    templateUrl: './main-feed-card.component.html',\n    styleUrls: ['./main-feed-card.component.scss'],\n})\nexport class MainFeedCardComponent implements OnDestroy, OnInit {\n    protected checkTimeout: any;\n\n    @ViewChild(FeedCommentFormComponent)\n    public FeedCommentFormControls: FeedCommentFormComponent;\n\n    @Input('active-environment')\n    public ActiveEnvironment: EaCEnvironmentAsCode;\n\n    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    @Input('environment')\n    public Environment: EaCEnvironmentAsCode;\n\n    @Input('feed-item')\n    public FeedItem: FeedItem;\n\n    // public get ActiveEnvironment(): EaCEnvironmentAsCode {\n    //     return this.State?.EaC?.Environments[this.ActiveEnvironmentLookup];\n    // }\n\n    // public get ActiveEnvironmentLookup(): string {\n    //     //  TODO:  Eventually support multiple environments\n    //     const envLookups = Object.keys(this.State?.EaC?.Environments || {});\n\n    //     return envLookups[0];\n    // }\n\n    public get CommentControl(): AbstractControl {\n        return this.FeedCommentFormControls?.FeedCommentsFormGroup?.controls\n            .comment;\n    }\n\n    public Icon: string;\n\n    public IconColor: string;\n\n    constructor(\n        protected eacSvc: EaCService,\n        protected dialog: MatDialog,\n        private sanitizer: DomSanitizer,\n        protected formBuilder: FormBuilder\n    ) {}\n\n    //  Life Cycle\n    public ngOnDestroy(): void {\n        if (this.checkTimeout) {\n            clearTimeout(this.checkTimeout);\n        }\n    }\n\n    public ngOnInit(): void {\n        this.handleRefresh();\n        this.SanitizeVideos();\n    }\n\n    public ngOnChanges() {\n        if (this.FeedItem.Status.Code === 0) {\n            this.Icon = 'check_circle';\n            this.IconColor = 'green';\n        } else if (this.FeedItem.Status.Code === 1) {\n            this.Icon = 'cancel';\n            this.IconColor = 'red';\n        } else if (this.FeedItem.Status.Code === 2) {\n            this.Icon = 'sync';\n            this.IconColor = 'blue';\n        } else {\n            this.Icon = 'help_outline';\n            this.IconColor = 'gray';\n        }\n    }\n\n    //  API Methods\n    public CalculateTimelapse(timestamp: Date) {\n        return moment(timestamp).fromNow();\n    }\n\n    public HandleAction(action: FeedItemAction) {\n        if (action.ActionType == 'Link') {\n            if (action.Action.startsWith('http')) {\n                window.open(action.Action, '_blank');\n            } else {\n                window.location.href = action.Action;\n            }\n        } else if (action.ActionType == 'Modal') {\n            if (action.Action == 'AddSourceControl') {\n                this.OpenSourceControlDialog(null, null);\n            } else {\n                alert('other modaled ' + action.Action);\n            }\n        }\n    }\n\n    public HandleSubmitComment(event: any) {\n        console.log('recieved comment: ', event);\n    }\n\n    public OpenSourceControlDialog(scLookup: string, scName: string): void {\n        const dialogRef = this.dialog.open(SourceControlDialogComponent, {\n            width: '550px',\n            data: {\n                environment: this.Environment,\n                environmentLookup: this.ActiveEnvironmentLookup,\n                scLookup: scLookup,\n                scName: scName,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public SafeHtml(html: string): SafeHtml {\n        return this.sanitizer.bypassSecurityTrustHtml(html);\n    }\n\n    public SanitizeVideos() {\n        this.FeedItem?.Tabs?.forEach((tab) => {\n            if (tab.Data.Video) {\n                tab.Data.Video = this.SafeHtml(tab.Data.Video);\n            }\n        });\n    }\n\n    public SubmitComment() {\n        console.log('comment: ', this.CommentControl.value);\n    }\n\n    //  Helpers\n\n    protected handleRefresh(): void {\n        if (this.FeedItem?.RefreshLink) {\n            this.checkTimeout = setTimeout(() => {\n                this.eacSvc.CheckUserFeedItem(this.FeedItem).subscribe(\n                    async (response: BaseModeledResponse<FeedItem>) => {\n                        if (response.Status.Code === 0) {\n                            this.FeedItem = response.Model;\n\n                            this.handleRefresh();\n                        } else {\n                            console.log(response);\n                        }\n                    },\n                    (err) => {\n                        console.log(err);\n                    }\n                );\n            }, 30000);\n        }\n    }\n}\n","<mat-card class=\"social-card\">\n    <mat-card-header>\n        <img\n            mat-card-avatar\n            class=\"example-header-image\"\n            [src]=\"FeedItem.Avatar\"\n            *ngIf=\"FeedItem.Avatar\"\n        />\n\n        <mat-card-title *ngIf=\"FeedItem.Title\" class=\"feed-item-title\">{{\n            FeedItem.Title\n        }}</mat-card-title>\n\n        <mat-card-subtitle>\n            <div *ngIf=\"FeedItem.Subtitle\">{{ FeedItem.Subtitle }}</div>\n\n            <div *ngIf=\"FeedItem.Subtext\">{{ FeedItem.Subtext }}</div>\n\n            <div *ngIf=\"FeedItem.Status\">\n                <mat-icon\n                    *ngIf=\"Icon\"\n                    [style.color]=\"IconColor\"\n                    [class.spin]=\"FeedItem.Status?.Code == 2\"\n                >\n                    {{ Icon }}\n                </mat-icon>\n\n                <span *ngIf=\"FeedItem.Status?.Message\">\n                    {{ FeedItem.Status?.Message }}\n                </span>\n\n                <span *ngIf=\"FeedItem.Timestamp\">\n                    {{ CalculateTimelapse(FeedItem.Timestamp) }}\n                </span>\n            </div>\n        </mat-card-subtitle>\n    </mat-card-header>\n\n    <div *ngIf=\"!FeedItem.IsShortForm\">\n        <div class=\"feed-card-container\">\n            <div class=\"feed-card-main-content\">\n                <mat-tab-group>\n                    <ng-container *ngFor=\"let tab of FeedItem.Tabs\">\n                        <mat-tab [label]=\"tab.Title\">\n                            <div class=\"tab\">\n                                <ng-container *ngIf=\"tab.Data?.Commit?.Message\">\n                                    <div\n                                        class=\"commit-message\"\n                                        [innerHTML]=\"\n                                            SafeHtml(tab.Data?.Commit?.Message)\n                                        \"\n                                    ></div>\n                                </ng-container>\n\n                                <ng-container *ngIf=\"tab.Data?.Content\">\n                                    <div\n                                        class=\"content\"\n                                        [innerHTML]=\"\n                                            SafeHtml(tab.Data?.Content)\n                                        \"\n                                    ></div>\n                                </ng-container>\n\n                                <ng-container *ngIf=\"tab.Data?.Video\">\n                                    <div\n                                        class=\"video\"\n                                        [innerHTML]=\"tab.Data.Video\"\n                                    ></div>\n                                </ng-container>\n\n                                <ng-container *ngIf=\"tab.Data?.Comments\">\n                                    <div class=\"comments\">\n                                        <ng-container\n                                            *ngIf=\"\n                                                tab.Data?.Comments?.length <= 0\n                                            \"\n                                        >\n                                            <h4>No comments provided</h4>\n                                        </ng-container>\n\n                                        <mat-card\n                                            *ngFor=\"\n                                                let comment of tab.Data\n                                                    ?.Comments\n                                            \"\n                                        >\n                                            <mat-card-header>\n                                                <img\n                                                    mat-card-avatar\n                                                    class=\"example-header-image\"\n                                                    [src]=\"comment.Avatar\"\n                                                    *ngIf=\"comment.Avatar\"\n                                                />\n\n                                                <mat-card-title>\n                                                    {{ comment.Author }}\n                                                    commented on\n                                                    {{ comment.UpdatedAt }}\n                                                </mat-card-title>\n                                            </mat-card-header>\n\n                                            <mat-card-content\n                                                [innerHTML]=\"\n                                                    SafeHtml(comment.Comment)\n                                                \"\n                                            >\n                                            </mat-card-content>\n                                        </mat-card>\n                                        <!-- <lcu-feed-comment-form\n                                            (submit-event)=\"\n                                                HandleSubmitComment($event)\n                                            \"\n                                        >\n                                        </lcu-feed-comment-form> -->\n                                    </div>\n                                </ng-container>\n                            </div>\n                        </mat-tab>\n                    </ng-container>\n                </mat-tab-group>\n            </div>\n        </div>\n    </div>\n\n    <mat-card-actions fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n        <div fxFlex></div>\n\n        <ng-container *ngFor=\"let action of FeedItem.Actions\">\n            <button\n                mat-raised-button\n                [color]=\"action.Color\"\n                (click)=\"HandleAction(action)\"\n            >\n                <mat-icon *ngIf=\"action.Icon\">{{ action.Icon }}</mat-icon>\n\n                {{ action.Text }}\n            </button>\n        </ng-container>\n    </mat-card-actions>\n</mat-card>\n"]}
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main-feed-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/main-feed-card/main-feed-card.component.ts","../../../../../../projects/common/src/lib/elements/main-feed-card/main-feed-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, OnDestroy, ViewChild } from '@angular/core';\nimport { FeedItem, FeedItemAction } from '../../models/user-feed.model';\nimport moment from 'moment';\nimport { EaCService } from '../../services/eac.service';\nimport { BaseModeledResponse } from '@lcu/common';\nimport { SourceControlDialogComponent } from '../../dialogs/source-control-dialog/source-control-dialog.component';\nimport { MatDialog } from '@angular/material/dialog';\nimport { EaCEnvironmentAsCode } from '@semanticjs/common';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { AbstractControl, FormBuilder } from '@angular/forms';\nimport { FeedCommentFormComponent } from '../../controls/feed-comment-form/feed-comment-form.component';\n\n@Component({\n    selector: 'lcu-main-feed-card',\n    templateUrl: './main-feed-card.component.html',\n    styleUrls: ['./main-feed-card.component.scss'],\n})\nexport class MainFeedCardComponent implements OnDestroy, OnInit {\n    protected checkTimeout: any;\n\n    @ViewChild(FeedCommentFormComponent)\n    public FeedCommentFormControls: FeedCommentFormComponent;\n\n    @Input('active-environment')\n    public ActiveEnvironment: EaCEnvironmentAsCode;\n\n    @Input('active-environment-lookup')\n    public ActiveEnvironmentLookup: string;\n\n    @Input('environment')\n    public Environment: EaCEnvironmentAsCode;\n\n    @Input('feed-item')\n    public FeedItem: FeedItem;\n\n    // public get ActiveEnvironment(): EaCEnvironmentAsCode {\n    //     return this.State?.EaC?.Environments[this.ActiveEnvironmentLookup];\n    // }\n\n    // public get ActiveEnvironmentLookup(): string {\n    //     //  TODO:  Eventually support multiple environments\n    //     const envLookups = Object.keys(this.State?.EaC?.Environments || {});\n\n    //     return envLookups[0];\n    // }\n\n    public get CommentControl(): AbstractControl {\n        return this.FeedCommentFormControls?.FeedCommentsFormGroup?.controls\n            .comment;\n    }\n\n    public Icon: string;\n\n    public IconColor: string;\n\n    constructor(\n        protected eacSvc: EaCService,\n        protected dialog: MatDialog,\n        private sanitizer: DomSanitizer,\n        protected formBuilder: FormBuilder\n    ) {}\n\n    //  Life Cycle\n    public ngOnDestroy(): void {\n        if (this.checkTimeout) {\n            clearTimeout(this.checkTimeout);\n        }\n    }\n\n    public ngOnInit(): void {\n        this.handleRefresh();\n        this.SanitizeVideos();\n    }\n\n    public ngOnChanges() {\n        if (this.FeedItem?.Status?.Code === 0) {\n            this.Icon = 'check_circle';\n            this.IconColor = 'green';\n        } else if (this.FeedItem?.Status?.Code === 1) {\n            this.Icon = 'cancel';\n            this.IconColor = 'red';\n        } else if (this.FeedItem?.Status?.Code === 2) {\n            this.Icon = 'sync';\n            this.IconColor = 'blue';\n        } else {\n            this.Icon = 'help_outline';\n            this.IconColor = 'gray';\n        }\n    }\n\n    //  API Methods\n    public CalculateTimelapse(timestamp: Date) {\n        return moment(timestamp).fromNow();\n    }\n\n    public HandleAction(action: FeedItemAction) {\n        if (action.ActionType == 'Link') {\n            if (action.Action.startsWith('http')) {\n                window.open(action.Action, '_blank');\n            } else {\n                window.location.href = action.Action;\n            }\n        } else if (action.ActionType == 'Modal') {\n            if (action.Action == 'AddSourceControl') {\n                this.OpenSourceControlDialog(null, null);\n            } else {\n                alert('other modaled ' + action.Action);\n            }\n        }\n    }\n\n    public HandleSubmitComment(event: any) {\n        console.log('recieved comment: ', event);\n    }\n\n    public OpenSourceControlDialog(scLookup: string, scName: string): void {\n        const dialogRef = this.dialog.open(SourceControlDialogComponent, {\n            width: '550px',\n            data: {\n                environment: this.Environment,\n                environmentLookup: this.ActiveEnvironmentLookup,\n                scLookup: scLookup,\n                scName: scName,\n            },\n        });\n\n        dialogRef.afterClosed().subscribe((result: any) => {\n            // console.log('The dialog was closed');\n            // console.log(\"result:\", result)\n        });\n    }\n\n    public SafeHtml(html: string): SafeHtml {\n        return this.sanitizer.bypassSecurityTrustHtml(html);\n    }\n\n    public SanitizeVideos() {\n        this.FeedItem?.Tabs?.forEach((tab) => {\n            if (tab.Data.Video) {\n                tab.Data.Video = this.SafeHtml(tab.Data.Video);\n            }\n        });\n    }\n\n    public SubmitComment() {\n        console.log('comment: ', this.CommentControl.value);\n    }\n\n    //  Helpers\n\n    protected handleRefresh(): void {\n        if (this.FeedItem?.RefreshLink) {\n            this.checkTimeout = setTimeout(() => {\n                this.eacSvc.CheckUserFeedItem(this.FeedItem).subscribe(\n                    async (response: BaseModeledResponse<FeedItem>) => {\n                        if (response.Status.Code === 0) {\n                            this.FeedItem = response.Model;\n\n                            this.handleRefresh();\n                        } else {\n                            console.log(response);\n                        }\n                    },\n                    (err: any) => {\n                        console.log(err);\n                    }\n                );\n            }, 30000);\n        }\n    }\n}\n","<mat-card class=\"social-card\">\n    <mat-card-header>\n        <img\n            mat-card-avatar\n            class=\"example-header-image\"\n            [src]=\"FeedItem.Avatar\"\n            *ngIf=\"FeedItem.Avatar\"\n        />\n\n        <mat-card-title *ngIf=\"FeedItem.Title\" class=\"feed-item-title\">{{\n            FeedItem.Title\n        }}</mat-card-title>\n\n        <mat-card-subtitle>\n            <div *ngIf=\"FeedItem.Subtitle\">{{ FeedItem.Subtitle }}</div>\n\n            <div *ngIf=\"FeedItem.Subtext\">{{ FeedItem.Subtext }}</div>\n\n            <div *ngIf=\"FeedItem.Status\">\n                <mat-icon\n                    *ngIf=\"Icon\"\n                    [style.color]=\"IconColor\"\n                    [class.spin]=\"FeedItem.Status?.Code == 2\"\n                >\n                    {{ Icon }}\n                </mat-icon>\n\n                <span *ngIf=\"FeedItem.Status?.Message\">\n                    {{ FeedItem.Status?.Message }}\n                </span>\n\n                <span *ngIf=\"FeedItem.Timestamp\">\n                    {{ CalculateTimelapse(FeedItem.Timestamp) }}\n                </span>\n            </div>\n        </mat-card-subtitle>\n    </mat-card-header>\n\n    <div *ngIf=\"!FeedItem.IsShortForm\">\n        <div class=\"feed-card-container\">\n            <div class=\"feed-card-main-content\">\n                <mat-tab-group>\n                    <ng-container *ngFor=\"let tab of FeedItem.Tabs\">\n                        <mat-tab [label]=\"tab.Title\">\n                            <div class=\"tab\">\n                                <ng-container *ngIf=\"tab.Data?.Commit?.Message\">\n                                    <div\n                                        class=\"commit-message\"\n                                        [innerHTML]=\"\n                                            SafeHtml(tab.Data?.Commit?.Message)\n                                        \"\n                                    ></div>\n                                </ng-container>\n\n                                <ng-container *ngIf=\"tab.Data?.Content\">\n                                    <div\n                                        class=\"content\"\n                                        [innerHTML]=\"\n                                            SafeHtml(tab.Data?.Content)\n                                        \"\n                                    ></div>\n                                </ng-container>\n\n                                <ng-container *ngIf=\"tab.Data?.Video\">\n                                    <div\n                                        class=\"video\"\n                                        [innerHTML]=\"tab.Data.Video\"\n                                    ></div>\n                                </ng-container>\n\n                                <ng-container *ngIf=\"tab.Data?.Comments\">\n                                    <div class=\"comments\">\n                                        <ng-container\n                                            *ngIf=\"\n                                                tab.Data?.Comments?.length <= 0\n                                            \"\n                                        >\n                                            <h4>No comments provided</h4>\n                                        </ng-container>\n\n                                        <mat-card\n                                            *ngFor=\"\n                                                let comment of tab.Data\n                                                    ?.Comments\n                                            \"\n                                        >\n                                            <mat-card-header>\n                                                <img\n                                                    mat-card-avatar\n                                                    class=\"example-header-image\"\n                                                    [src]=\"comment.Avatar\"\n                                                    *ngIf=\"comment.Avatar\"\n                                                />\n\n                                                <mat-card-title>\n                                                    {{ comment.Author }}\n                                                    commented on\n                                                    {{ comment.UpdatedAt }}\n                                                </mat-card-title>\n                                            </mat-card-header>\n\n                                            <mat-card-content\n                                                [innerHTML]=\"\n                                                    SafeHtml(comment.Comment)\n                                                \"\n                                            >\n                                            </mat-card-content>\n                                        </mat-card>\n                                        <!-- <lcu-feed-comment-form\n                                            (submit-event)=\"\n                                                HandleSubmitComment($event)\n                                            \"\n                                        >\n                                        </lcu-feed-comment-form> -->\n                                    </div>\n                                </ng-container>\n                            </div>\n                        </mat-tab>\n                    </ng-container>\n                </mat-tab-group>\n            </div>\n        </div>\n    </div>\n\n    <mat-card-actions fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n        <div fxFlex></div>\n\n        <ng-container *ngFor=\"let action of FeedItem.Actions\">\n            <button\n                mat-raised-button\n                [color]=\"action.Color\"\n                (click)=\"HandleAction(action)\"\n            >\n                <mat-icon *ngIf=\"action.Icon\">{{ action.Icon }}</mat-icon>\n\n                {{ action.Text }}\n            </button>\n        </ng-container>\n    </mat-card-actions>\n</mat-card>\n"]}