@provoly/hypervisor 0.0.132 → 0.0.134

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.
@@ -5,6 +5,19 @@ import * as i1 from "../../store/comments/comments.service";
5
5
  import * as i2 from "@angular/forms";
6
6
  import * as i3 from "@provoly/dashboard";
7
7
  export class HvyCommentsComponent {
8
+ set lastComment(comment) {
9
+ this._lastComment = !comment
10
+ ? undefined
11
+ : {
12
+ ...comment,
13
+ day: new Date(comment.lastModificationDate).toLocaleDateString(),
14
+ hour: new Date(comment.lastModificationDate)
15
+ .toLocaleTimeString()
16
+ .substring(0, new Date(comment.lastModificationDate).toLocaleTimeString().lastIndexOf(':')),
17
+ edit: false,
18
+ previousMessage: comment.message
19
+ };
20
+ }
8
21
  set trigger(trigger$) {
9
22
  this.subTrigger?.unsubscribe();
10
23
  this.subTrigger = trigger$.subscribe((opened) => (this.opened = opened ?? !this.opened));
@@ -18,7 +31,6 @@ export class HvyCommentsComponent {
18
31
  this.type = 'events';
19
32
  this.displayEmpty = true;
20
33
  this.commentCount = 0;
21
- this.lastComment = undefined;
22
34
  this.opened = false;
23
35
  this.additionnalComments = [];
24
36
  }
@@ -26,15 +38,7 @@ export class HvyCommentsComponent {
26
38
  this.subTrigger?.unsubscribe();
27
39
  }
28
40
  get comments() {
29
- return [this.lastComment, ...this.additionnalComments].filter((comment) => !!comment).map((comment) => ({
30
- ...comment,
31
- day: new Date(comment.lastModificationDate).toLocaleDateString(),
32
- hour: new Date(comment.lastModificationDate)
33
- .toLocaleTimeString()
34
- .substring(0, new Date(comment.lastModificationDate).toLocaleTimeString().lastIndexOf(':')),
35
- edit: false,
36
- previousMessage: comment.message
37
- }));
41
+ return [this._lastComment, ...this.additionnalComments].filter((com) => !!com);
38
42
  }
39
43
  addComment() {
40
44
  this.commented.next({ id: v4(), message: this.newComment });
@@ -56,7 +60,17 @@ export class HvyCommentsComponent {
56
60
  toggleMore() {
57
61
  if (!this.more) {
58
62
  this.commentsService.get(this.objectId, this.type).subscribe((comments) => {
59
- this.additionnalComments = comments.filter((comment) => comment.id !== this.lastComment.id);
63
+ this.additionnalComments = comments
64
+ .filter((comment) => comment.id !== this._lastComment?.id)
65
+ .map((comment) => ({
66
+ ...comment,
67
+ day: new Date(comment.lastModificationDate).toLocaleDateString(),
68
+ hour: new Date(comment.lastModificationDate)
69
+ .toLocaleTimeString()
70
+ .substring(0, new Date(comment.lastModificationDate).toLocaleTimeString().lastIndexOf(':')),
71
+ edit: false,
72
+ previousMessage: comment.message
73
+ }));
60
74
  this.more = !this.more;
61
75
  });
62
76
  }
@@ -92,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
92
106
  }], trigger: [{
93
107
  type: Input
94
108
  }] } });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comments.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/general/comments/comments.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/general/comments/comments.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { HypComment } from '../../model/comment.interface';\nimport { v4 } from 'uuid';\nimport { Subject, Subscription } from 'rxjs';\nimport { HypCommentsService } from '../../store/comments/comments.service';\n\nexport type HypAugmentedComment = HypComment & {\n  day: string;\n  hour: string;\n  edit: boolean;\n  previousMessage: string;\n};\n\n@Component({\n  selector: 'hvy-comments',\n  templateUrl: './comments.component.html'\n})\nexport class HvyCommentsComponent implements OnDestroy {\n  @Input() readonly: boolean | null = false;\n  newComment = '';\n  @Output() commented = new EventEmitter<{ id: string; message: string }>();\n  more = false;\n  @Input() me: string | null | undefined;\n  @Input() type: 'actions' | 'events' = 'events';\n  @Input() objectId?: string | number;\n  @Input() displayEmpty = true;\n  @Input() commentCount = 0;\n  @Input() lastComment?: HypComment = undefined;\n  opened = false;\n  subTrigger?: Subscription;\n  additionnalComments: HypComment[] = [];\n\n  @Input() set trigger(trigger$: Subject<boolean>) {\n    this.subTrigger?.unsubscribe();\n    this.subTrigger = trigger$.subscribe((opened) => (this.opened = opened ?? !this.opened));\n  }\n\n  constructor(private commentsService: HypCommentsService) {}\n\n  ngOnDestroy(): void {\n    this.subTrigger?.unsubscribe();\n  }\n\n  get comments() {\n    return ([this.lastComment, ...this.additionnalComments].filter((comment) => !!comment) as HypComment[]).map(\n      (comment: HypComment) =>\n        ({\n          ...comment,\n          day: new Date(comment.lastModificationDate).toLocaleDateString(),\n          hour: new Date(comment.lastModificationDate)\n            .toLocaleTimeString()\n            .substring(0, new Date(comment.lastModificationDate).toLocaleTimeString().lastIndexOf(':')),\n          edit: false,\n          previousMessage: comment.message\n        }) as HypAugmentedComment\n    ) as HypAugmentedComment[];\n  }\n\n  addComment() {\n    this.commented.next({ id: v4(), message: this.newComment });\n    this.newComment = '';\n    this.more = false;\n  }\n\n  editComment(comment: HypAugmentedComment) {\n    comment.edit = true;\n  }\n\n  saveComment(comment: HypAugmentedComment) {\n    this.commented.next({ id: comment.id, message: comment.message });\n    comment.edit = false;\n    this.more = false;\n  }\n\n  cancel(comment: HypAugmentedComment) {\n    comment.message = comment.previousMessage;\n    comment.edit = false;\n  }\n\n  toggleMore() {\n    if (!this.more) {\n      this.commentsService.get(this.objectId!, this.type).subscribe((comments) => {\n        this.additionnalComments = comments.filter((comment) => comment.id !== this.lastComment!.id);\n        this.more = !this.more;\n      });\n    } else {\n      this.more = !this.more;\n    }\n  }\n\n  toggle() {\n    this.opened = !this.opened;\n  }\n}\n","<div class=\"o-hvy-comments\">\n  @if (displayEmpty || commentCount > 0 || opened) {\n    <div class=\"o-hvy-comments__header\">\n      @if (type === 'actions') {\n        <pry-icon\n          iconSvg=\"arrow_down_rounded\"\n          [class.-rotated]=\"opened\"\n          class=\"-hand\"\n          (click)=\"toggle()\"\n          [width]=\"10\"\n          [height]=\"10\"\n        ></pry-icon>\n      }\n      <h3>\n        {{\n          (type === 'events' ? '@hvy.event.log.event.comments.name' : '@hvy.event.log.event.comments.actions')\n            | i18n: { nb: commentCount }\n        }}\n      </h3>\n    </div>\n\n    @if (!readonly && (displayEmpty || opened)) {\n      <textarea\n        class=\"a-form-field\"\n        [placeholder]=\"('@hvy.event.log.event.comments.placeholder' | i18n) + '...'\"\n        [(ngModel)]=\"newComment\"\n        maxlength=\"255\"\n      ></textarea>\n      <div class=\"o-hvy-comments__button\">\n        <button class=\"a-btn a-btn--primary\" [disabled]=\"newComment.length === 0\" (click)=\"addComment()\">\n          {{ '@hvy.action.comment' | i18n }}\n        </button>\n      </div>\n    }\n\n    @if (displayEmpty || opened) {\n      @for (comment of comments; track comment.id) {\n        @if ($first || more) {\n          <div class=\"o-hvy-comments__previous\">\n            <span class=\"o-hvy-comments__previous__title\">{{\n              ($first && commentCount > 1 ? '@hvy.event.comment.lastDetail' : '@hvy.event.comment.detail')\n                | i18n\n                  : {\n                      day: comment.day,\n                      hour: comment.hour,\n                      creator: comment.creatorName ?? '-'\n                    }\n            }}</span>\n            <div class=\"o-hvy-comments__previous__message\">\n              <textarea\n                class=\"a-form-field\"\n                [(ngModel)]=\"comment.message\"\n                [readonly]=\"!comment.edit\"\n                [placeholder]=\"('@hvy.event.log.event.comments.placeholder' | i18n) + '...'\"\n                maxlength=\"255\"\n              ></textarea>\n              @if (!readonly && (!me || comment.creator === me)) {\n                <button (click)=\"editComment(comment)\" [disabled]=\"comment.edit\">\n                  <pry-icon iconSvg=\"edit\" [height]=\"18\" [width]=\"18\"></pry-icon>\n                </button>\n              }\n            </div>\n            @if (comment.edit) {\n              <div class=\"o-hvy-comments__previous__actions\">\n                <button\n                  class=\"a-btn a-btn--primary\"\n                  [disabled]=\"comment.message.length === 0\"\n                  (click)=\"saveComment(comment)\"\n                >\n                  {{ '@hvy.action.update' | i18n }}\n                </button>\n                <button class=\"a-btn a-btn--secondary\" (click)=\"cancel(comment)\">\n                  {{ '@hvy.action.cancel' | i18n }}\n                </button>\n              </div>\n            }\n          </div>\n        }\n      }\n      @if (commentCount > 1) {\n        <div class=\"o-hvy-comments__more\">\n          <button (click)=\"toggleMore()\">\n            {{ (more ? '@hvy.event.comment.less' : '@hvy.event.comment.more') | i18n }}\n          </button>\n        </div>\n      }\n    }\n  }\n</div>\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comments.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/general/comments/comments.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/general/comments/comments.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { HypComment } from '../../model/comment.interface';\nimport { v4 } from 'uuid';\nimport { Subject, Subscription } from 'rxjs';\nimport { HypCommentsService } from '../../store/comments/comments.service';\n\nexport type HypAugmentedComment = HypComment & {\n  day: string;\n  hour: string;\n  edit: boolean;\n  previousMessage: string;\n};\n\n@Component({\n  selector: 'hvy-comments',\n  templateUrl: './comments.component.html'\n})\nexport class HvyCommentsComponent implements OnDestroy {\n  @Input() readonly: boolean | null = false;\n  newComment = '';\n  @Output() commented = new EventEmitter<{ id: string; message: string }>();\n  more = false;\n  @Input() me: string | null | undefined;\n  @Input() type: 'actions' | 'events' = 'events';\n  @Input() objectId?: string | number;\n  @Input() displayEmpty = true;\n  @Input() commentCount = 0;\n  opened = false;\n  subTrigger?: Subscription;\n  additionnalComments: HypAugmentedComment[] = [];\n  _lastComment: HypAugmentedComment | undefined;\n  @Input() set lastComment(comment: HypComment | undefined) {\n    this._lastComment = !comment\n      ? undefined\n      : ({\n          ...comment,\n          day: new Date(comment.lastModificationDate).toLocaleDateString(),\n          hour: new Date(comment.lastModificationDate)\n            .toLocaleTimeString()\n            .substring(0, new Date(comment.lastModificationDate).toLocaleTimeString().lastIndexOf(':')),\n          edit: false,\n          previousMessage: comment.message\n        } as HypAugmentedComment);\n  }\n\n  @Input() set trigger(trigger$: Subject<boolean>) {\n    this.subTrigger?.unsubscribe();\n    this.subTrigger = trigger$.subscribe((opened) => (this.opened = opened ?? !this.opened));\n  }\n\n  constructor(private commentsService: HypCommentsService) {}\n\n  ngOnDestroy(): void {\n    this.subTrigger?.unsubscribe();\n  }\n\n  get comments(): HypAugmentedComment[] {\n    return [this._lastComment, ...this.additionnalComments].filter((com) => !!com) as HypAugmentedComment[];\n  }\n\n  addComment() {\n    this.commented.next({ id: v4(), message: this.newComment });\n    this.newComment = '';\n    this.more = false;\n  }\n\n  editComment(comment: HypAugmentedComment) {\n    comment.edit = true;\n  }\n\n  saveComment(comment: HypAugmentedComment) {\n    this.commented.next({ id: comment.id, message: comment.message });\n    comment.edit = false;\n    this.more = false;\n  }\n\n  cancel(comment: HypAugmentedComment) {\n    comment.message = comment.previousMessage;\n    comment.edit = false;\n  }\n\n  toggleMore() {\n    if (!this.more) {\n      this.commentsService.get(this.objectId!, this.type).subscribe((comments) => {\n        this.additionnalComments = comments\n          .filter((comment) => comment.id !== this._lastComment?.id)\n          .map(\n            (comment: HypComment) =>\n              ({\n                ...comment,\n                day: new Date(comment.lastModificationDate).toLocaleDateString(),\n                hour: new Date(comment.lastModificationDate)\n                  .toLocaleTimeString()\n                  .substring(0, new Date(comment.lastModificationDate).toLocaleTimeString().lastIndexOf(':')),\n                edit: false,\n                previousMessage: comment.message\n              }) as HypAugmentedComment\n          );\n        this.more = !this.more;\n      });\n    } else {\n      this.more = !this.more;\n    }\n  }\n\n  toggle() {\n    this.opened = !this.opened;\n  }\n}\n","<div class=\"o-hvy-comments\">\n  @if (displayEmpty || commentCount > 0 || opened) {\n    <div class=\"o-hvy-comments__header\">\n      @if (type === 'actions') {\n        <pry-icon\n          iconSvg=\"arrow_down_rounded\"\n          [class.-rotated]=\"opened\"\n          class=\"-hand\"\n          (click)=\"toggle()\"\n          [width]=\"10\"\n          [height]=\"10\"\n        ></pry-icon>\n      }\n      <h3>\n        {{\n          (type === 'events' ? '@hvy.event.log.event.comments.name' : '@hvy.event.log.event.comments.actions')\n            | i18n: { nb: commentCount }\n        }}\n      </h3>\n    </div>\n\n    @if (!readonly && (displayEmpty || opened)) {\n      <textarea\n        class=\"a-form-field\"\n        [placeholder]=\"('@hvy.event.log.event.comments.placeholder' | i18n) + '...'\"\n        [(ngModel)]=\"newComment\"\n        maxlength=\"255\"\n      ></textarea>\n      <div class=\"o-hvy-comments__button\">\n        <button class=\"a-btn a-btn--primary\" [disabled]=\"newComment.length === 0\" (click)=\"addComment()\">\n          {{ '@hvy.action.comment' | i18n }}\n        </button>\n      </div>\n    }\n\n    @if (displayEmpty || opened) {\n      @for (comment of comments; track comment.id) {\n        @if ($first || more) {\n          <div class=\"o-hvy-comments__previous\">\n            <span class=\"o-hvy-comments__previous__title\">{{\n              ($first && commentCount > 1 ? '@hvy.event.comment.lastDetail' : '@hvy.event.comment.detail')\n                | i18n\n                  : {\n                      day: comment.day,\n                      hour: comment.hour,\n                      creator: comment.creatorName ?? '-'\n                    }\n            }}</span>\n            <div class=\"o-hvy-comments__previous__message\">\n              <textarea\n                class=\"a-form-field\"\n                [(ngModel)]=\"comment.message\"\n                [readonly]=\"!comment.edit\"\n                [placeholder]=\"('@hvy.event.log.event.comments.placeholder' | i18n) + '...'\"\n                maxlength=\"255\"\n              ></textarea>\n              @if (!readonly && (!me || comment.creator === me)) {\n                <button (click)=\"editComment(comment)\" [disabled]=\"comment.edit\">\n                  <pry-icon iconSvg=\"edit\" [height]=\"18\" [width]=\"18\"></pry-icon>\n                </button>\n              }\n            </div>\n            @if (comment.edit) {\n              <div class=\"o-hvy-comments__previous__actions\">\n                <button\n                  class=\"a-btn a-btn--primary\"\n                  [disabled]=\"comment.message.length === 0\"\n                  (click)=\"saveComment(comment)\"\n                >\n                  {{ '@hvy.action.update' | i18n }}\n                </button>\n                <button class=\"a-btn a-btn--secondary\" (click)=\"cancel(comment)\">\n                  {{ '@hvy.action.cancel' | i18n }}\n                </button>\n              </div>\n            }\n          </div>\n        }\n      }\n      @if (commentCount > 1) {\n        <div class=\"o-hvy-comments__more\">\n          <button (click)=\"toggleMore()\">\n            {{ (more ? '@hvy.event.comment.less' : '@hvy.event.comment.more') | i18n }}\n          </button>\n        </div>\n      }\n    }\n  }\n</div>\n"]}
@@ -810,6 +810,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
810
810
  }] } });
811
811
 
812
812
  class HvyCommentsComponent {
813
+ set lastComment(comment) {
814
+ this._lastComment = !comment
815
+ ? undefined
816
+ : {
817
+ ...comment,
818
+ day: new Date(comment.lastModificationDate).toLocaleDateString(),
819
+ hour: new Date(comment.lastModificationDate)
820
+ .toLocaleTimeString()
821
+ .substring(0, new Date(comment.lastModificationDate).toLocaleTimeString().lastIndexOf(':')),
822
+ edit: false,
823
+ previousMessage: comment.message
824
+ };
825
+ }
813
826
  set trigger(trigger$) {
814
827
  this.subTrigger?.unsubscribe();
815
828
  this.subTrigger = trigger$.subscribe((opened) => (this.opened = opened ?? !this.opened));
@@ -823,7 +836,6 @@ class HvyCommentsComponent {
823
836
  this.type = 'events';
824
837
  this.displayEmpty = true;
825
838
  this.commentCount = 0;
826
- this.lastComment = undefined;
827
839
  this.opened = false;
828
840
  this.additionnalComments = [];
829
841
  }
@@ -831,15 +843,7 @@ class HvyCommentsComponent {
831
843
  this.subTrigger?.unsubscribe();
832
844
  }
833
845
  get comments() {
834
- return [this.lastComment, ...this.additionnalComments].filter((comment) => !!comment).map((comment) => ({
835
- ...comment,
836
- day: new Date(comment.lastModificationDate).toLocaleDateString(),
837
- hour: new Date(comment.lastModificationDate)
838
- .toLocaleTimeString()
839
- .substring(0, new Date(comment.lastModificationDate).toLocaleTimeString().lastIndexOf(':')),
840
- edit: false,
841
- previousMessage: comment.message
842
- }));
846
+ return [this._lastComment, ...this.additionnalComments].filter((com) => !!com);
843
847
  }
844
848
  addComment() {
845
849
  this.commented.next({ id: v4(), message: this.newComment });
@@ -861,7 +865,17 @@ class HvyCommentsComponent {
861
865
  toggleMore() {
862
866
  if (!this.more) {
863
867
  this.commentsService.get(this.objectId, this.type).subscribe((comments) => {
864
- this.additionnalComments = comments.filter((comment) => comment.id !== this.lastComment.id);
868
+ this.additionnalComments = comments
869
+ .filter((comment) => comment.id !== this._lastComment?.id)
870
+ .map((comment) => ({
871
+ ...comment,
872
+ day: new Date(comment.lastModificationDate).toLocaleDateString(),
873
+ hour: new Date(comment.lastModificationDate)
874
+ .toLocaleTimeString()
875
+ .substring(0, new Date(comment.lastModificationDate).toLocaleTimeString().lastIndexOf(':')),
876
+ edit: false,
877
+ previousMessage: comment.message
878
+ }));
865
879
  this.more = !this.more;
866
880
  });
867
881
  }