@provoly/hypervisor 0.0.133 → 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.
@@ -61,7 +61,7 @@ export class HvyCommentsComponent {
61
61
  if (!this.more) {
62
62
  this.commentsService.get(this.objectId, this.type).subscribe((comments) => {
63
63
  this.additionnalComments = comments
64
- .filter((comment) => comment.id !== this.lastComment.id)
64
+ .filter((comment) => comment.id !== this._lastComment?.id)
65
65
  .map((comment) => ({
66
66
  ...comment,
67
67
  day: new Date(comment.lastModificationDate).toLocaleDateString(),
@@ -106,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
106
106
  }], trigger: [{
107
107
  type: Input
108
108
  }] } });
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\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"]}
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"]}
@@ -866,7 +866,7 @@ class HvyCommentsComponent {
866
866
  if (!this.more) {
867
867
  this.commentsService.get(this.objectId, this.type).subscribe((comments) => {
868
868
  this.additionnalComments = comments
869
- .filter((comment) => comment.id !== this.lastComment.id)
869
+ .filter((comment) => comment.id !== this._lastComment?.id)
870
870
  .map((comment) => ({
871
871
  ...comment,
872
872
  day: new Date(comment.lastModificationDate).toLocaleDateString(),