@lowcodeunit/applications-flow-common 1.36.0 → 1.36.3-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/elements/feed-header/feed-header.component.mjs +3 -3
- package/esm2020/lib/elements/main-feed-card/main-feed-card.component.mjs +7 -2
- package/fesm2015/lowcodeunit-applications-flow-common.mjs +8 -3
- package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/fesm2020/lowcodeunit-applications-flow-common.mjs +8 -3
- package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/lib/elements/main-feed-card/main-feed-card.component.d.ts +4 -2
- package/package.json +1 -1
|
@@ -61,6 +61,11 @@ export class MainFeedCardComponent {
|
|
|
61
61
|
return this.eacSvc.State;
|
|
62
62
|
}
|
|
63
63
|
// Life Cycle
|
|
64
|
+
ngOnDestroy() {
|
|
65
|
+
if (this.checkTimeout) {
|
|
66
|
+
clearTimeout(this.checkTimeout);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
64
69
|
ngOnInit() {
|
|
65
70
|
this.handleRefresh();
|
|
66
71
|
}
|
|
@@ -107,7 +112,7 @@ export class MainFeedCardComponent {
|
|
|
107
112
|
// Helpers
|
|
108
113
|
handleRefresh() {
|
|
109
114
|
if (this.FeedItem?.RefreshLink) {
|
|
110
|
-
setTimeout(() => {
|
|
115
|
+
this.checkTimeout = setTimeout(() => {
|
|
111
116
|
this.eacSvc.CheckUserFeedItem(this.FeedItem).subscribe(async (response) => {
|
|
112
117
|
if (response.Status.Code === 0) {
|
|
113
118
|
this.FeedItem = response.Model;
|
|
@@ -132,4 +137,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
132
137
|
type: Input,
|
|
133
138
|
args: ['feed-item']
|
|
134
139
|
}] } });
|
|
135
|
-
//# 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 } from '@angular/core';\nimport { FeedItem, FeedItemAction } from '../../models/user-feed.model';\nimport moment from 'moment';\nimport { JsonHubProtocol } from '@aspnet/signalr';\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 { ApplicationsFlowState } from '../../state/applications-flow.state';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\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 OnInit {\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 Environment(): EaCEnvironmentAsCode {\n    // console.log(\"Ent Environment var: \", this.State?.EaC?.Environments[this.State?.EaC?.Enterprise?.PrimaryEnvironment]);\n    return this.State?.EaC?.Environments[\n      this.State?.EaC?.Enterprise?.PrimaryEnvironment\n    ];\n  }\n\n  @Input('feed-item')\n  public FeedItem: FeedItem;\n\n  public get Icon(): string {\n    if (this.FeedItem.Status.Code === 0) {\n      return 'check_circle';\n    } else if (this.FeedItem.Status.Code === 1) {\n      return 'cancel';\n    } else if (this.FeedItem.Status.Code === 2) {\n      return 'sync';\n    } else {\n      return 'help_outline';\n    }\n  }\n\n  public get IconColor(): string {\n    if (this.FeedItem.Status.Code === 0) {\n      return 'green';\n    } else if (this.FeedItem.Status.Code === 1) {\n      return 'red';\n    } else if (this.FeedItem.Status.Code === 2) {\n      return 'blue';\n    } else {\n      return 'gray';\n    }\n  }\n\n  public get State(): ApplicationsFlowState {\n    return this.eacSvc.State;\n  }\n\n  constructor(\n    protected eacSvc: EaCService,\n    protected dialog: MatDialog,\n    private sanitizer: DomSanitizer\n  ) {}\n\n  //  Life Cycle\n  public ngOnInit(): void {\n    this.handleRefresh();\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 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  //  Helpers\n  protected handleRefresh(): void {\n    if (this.FeedItem?.RefreshLink) {\n      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      }, 15000);\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\">{{ FeedItem.Title }}</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.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 class=\"commit-message\">\n                    {{ tab.Data?.Commit?.Message }}\n                  </div>\n                </ng-container>\n\n                <ng-container *ngIf=\"tab.Data?.Content\">\n                  <div class=\"content\">\n                    {{ tab.Data?.Content }}\n                  </div>\n                </ng-container>\n\n                <ng-container *ngIf=\"tab.Data?.Video\">\n                  <div\n                    class=\"video\"\n                    [innerHTML]=\"SafeHtml(tab.Data.Video)\"\n                  ></div>\n                </ng-container>\n\n                <ng-container *ngIf=\"tab.Data?.Comments\">\n                  <div class=\"comments\">\n                    <ng-container *ngIf=\"tab.Data?.Comments?.length <= 0\">\n                      <h4>No comments provided</h4>\n                    </ng-container>\n\n                    <mat-card *ngFor=\"let comment of tab.Data?.Comments\">\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                        {{ comment.Comment }}\n                      </mat-card-content>\n                    </mat-card>\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 mat-button [color]=\"action.Color\" (click)=\"HandleAction(action)\">\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"]}
|
|
140
|
+
//# 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 } from '@angular/core';\nimport { FeedItem, FeedItemAction } from '../../models/user-feed.model';\nimport moment from 'moment';\nimport { JsonHubProtocol } from '@aspnet/signalr';\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 { ApplicationsFlowState } from '../../state/applications-flow.state';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\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  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 Environment(): EaCEnvironmentAsCode {\n    // console.log(\"Ent Environment var: \", this.State?.EaC?.Environments[this.State?.EaC?.Enterprise?.PrimaryEnvironment]);\n    return this.State?.EaC?.Environments[\n      this.State?.EaC?.Enterprise?.PrimaryEnvironment\n    ];\n  }\n\n  @Input('feed-item')\n  public FeedItem: FeedItem;\n\n  public get Icon(): string {\n    if (this.FeedItem.Status.Code === 0) {\n      return 'check_circle';\n    } else if (this.FeedItem.Status.Code === 1) {\n      return 'cancel';\n    } else if (this.FeedItem.Status.Code === 2) {\n      return 'sync';\n    } else {\n      return 'help_outline';\n    }\n  }\n\n  public get IconColor(): string {\n    if (this.FeedItem.Status.Code === 0) {\n      return 'green';\n    } else if (this.FeedItem.Status.Code === 1) {\n      return 'red';\n    } else if (this.FeedItem.Status.Code === 2) {\n      return 'blue';\n    } else {\n      return 'gray';\n    }\n  }\n\n  public get State(): ApplicationsFlowState {\n    return this.eacSvc.State;\n  }\n\n  constructor(\n    protected eacSvc: EaCService,\n    protected dialog: MatDialog,\n    private sanitizer: DomSanitizer\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  }\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 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  //  Helpers\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      }, 15000);\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\">{{ FeedItem.Title }}</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.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 class=\"commit-message\">\n                    {{ tab.Data?.Commit?.Message }}\n                  </div>\n                </ng-container>\n\n                <ng-container *ngIf=\"tab.Data?.Content\">\n                  <div class=\"content\">\n                    {{ tab.Data?.Content }}\n                  </div>\n                </ng-container>\n\n                <ng-container *ngIf=\"tab.Data?.Video\">\n                  <div\n                    class=\"video\"\n                    [innerHTML]=\"SafeHtml(tab.Data.Video)\"\n                  ></div>\n                </ng-container>\n\n                <ng-container *ngIf=\"tab.Data?.Comments\">\n                  <div class=\"comments\">\n                    <ng-container *ngIf=\"tab.Data?.Comments?.length <= 0\">\n                      <h4>No comments provided</h4>\n                    </ng-container>\n\n                    <mat-card *ngFor=\"let comment of tab.Data?.Comments\">\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                        {{ comment.Comment }}\n                      </mat-card-content>\n                    </mat-card>\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 mat-button [color]=\"action.Color\" (click)=\"HandleAction(action)\">\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"]}
|