@tilde-nlp/ngx-common 4.1.27 → 4.1.28

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.
@@ -15,7 +15,13 @@ import * as i9 from "../../shared/llm-textarea/llm-textarea.component";
15
15
  import * as i10 from "@ngx-translate/core";
16
16
  export class CreateSummaryComponent {
17
17
  get isCreatingDisabled() {
18
- return this.isLoading || !this.text || !this.summaryQuotaLeft || this.isCharactersLimitExceeded;
18
+ return this.isLoading || !this.initialText || !this.summaryQuotaLeft;
19
+ }
20
+ get defaultErrorMessage() {
21
+ return this.llmHelperService.getDefaultErrorMessage();
22
+ }
23
+ get showMissingQuotaMessage() {
24
+ return !this.summaryQuotaLeft && !this.missingQuotaMessageClosed;
19
25
  }
20
26
  constructor(llmService, llmHelperService, quotaService, plausibleService, data) {
21
27
  this.llmService = llmService;
@@ -23,30 +29,33 @@ export class CreateSummaryComponent {
23
29
  this.quotaService = quotaService;
24
30
  this.plausibleService = plausibleService;
25
31
  this.data = data;
32
+ this.summarizedText = '';
33
+ this.manuallyEditedText = '';
26
34
  this.trialRequestCount = 15;
27
- this.summaryQuotaLocalStorageKey = 'LLM_SUMMARY_USAGE_KEY';
35
+ this.missingQuotaMessageClosed = false;
28
36
  }
29
37
  ngOnInit() {
30
- this.text = this.data.text;
38
+ this.initialText = this.data.text;
31
39
  this.language = this.data.language;
32
40
  this.subscriptionUrl = this.llmService.llmConfiguration.subscriptionUrl;
33
41
  this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();
34
- this.createSummary();
35
42
  this.refreshQuota();
36
43
  }
37
44
  createSummary() {
38
45
  this.isLoading = true;
39
46
  this.subscription = this.llmService
40
- .summarize({ text: this.text, language: this.language })
47
+ .summarize({ text: this.manuallyEditedText !== '' ? this.manuallyEditedText : this.initialText, language: this.language })
41
48
  .pipe(finalize(() => (this.isLoading = false)))
42
49
  .subscribe({
43
50
  next: (response) => {
44
- this.text = response;
45
- this.showErrorMessage = false;
51
+ this.isSummarized = true;
52
+ this.summarizedText = response;
53
+ this.manuallyEditedText = '';
54
+ this.showDefaultErrorMessage = false;
46
55
  this.refreshQuota(true);
47
56
  },
48
57
  error: () => {
49
- this.showErrorMessage = true;
58
+ this.showDefaultErrorMessage = true;
50
59
  }
51
60
  });
52
61
  }
@@ -59,36 +68,39 @@ export class CreateSummaryComponent {
59
68
  dislikeEvent() {
60
69
  this.plausibleService.summaryDislikeEvent();
61
70
  }
62
- checkCharactersLimit() {
63
- if (this.text.length > 10000) {
64
- this.isCharactersLimitExceeded = true;
65
- return;
66
- }
67
- this.isCharactersLimitExceeded = false;
71
+ textEditEvent(text) {
72
+ this.manuallyEditedText = text;
73
+ this.initialText = text;
68
74
  }
69
75
  refreshQuota(decrease) {
70
76
  this.quotaService.getQuotaUsage().pipe(finalize(() => this.setQuotaMessage())).subscribe({
71
77
  next: (response) => {
72
78
  const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_REQUESTS);
73
79
  if (!quota) {
74
- this.summaryQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(this.summaryQuotaLocalStorageKey, decrease);
80
+ this.setQuotaFromLocalStorage(decrease);
75
81
  return;
76
82
  }
77
83
  this.summaryQuotaLeft = quota.quotaRemaining;
78
84
  },
85
+ error: () => {
86
+ this.setQuotaFromLocalStorage(decrease);
87
+ }
79
88
  });
80
89
  }
81
90
  setQuotaMessage() {
82
91
  this.showRemainingQuotaMessage = this.summaryQuotaLeft <= this.trialRequestCount;
83
92
  }
93
+ setQuotaFromLocalStorage(decrease) {
94
+ this.summaryQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(decrease);
95
+ }
84
96
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CreateSummaryComponent, deps: [{ token: i1.LLMService }, { token: i2.LLMHelperService }, { token: i3.QuotaService }, { token: i4.PlausibleService }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
85
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CreateSummaryComponent, selector: "lib-create-summary", ngImport: i0, template: "<h1 mat-dialog-title>{{ \"LLM.SUMMARY_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n <p>{{ \"LLM.SUMMARY_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n <lib-tld-notification-message *ngIf=\"!summaryQuotaLeft\" [message]=\"reachedQuotaMessage\"></lib-tld-notification-message>\r\n\r\n <lib-llm-textarea [showErrorMessage]=\"showErrorMessage\" [text]=\"text\" [disabled]=\"isLoading || !summaryQuotaLeft\" (textEditEvent)=\"text = $event; checkCharactersLimit()\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-summary-actions-wrapper\" mat-dialog-actions>\r\n <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.SUMMARY_MODAL.LIMIT' | translate: { limit: summaryQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-summary-actions\">\r\n <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n {{ \"LLM.SUMMARY_MODAL.CANCEL\" | translate }}\r\n </button>\r\n\r\n <ng-template #closeButton>\r\n <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n {{ \"LLM.SUMMARY_MODAL.CLOSE\" | translate }}\r\n </button>\r\n </ng-template>\r\n \r\n <button\r\n mat-flat-button\r\n color=\"accent\"\r\n (click)=\"createSummary()\"\r\n [disabled]=\"isCreatingDisabled\"\r\n >\r\n {{\r\n (isLoading\r\n ? \"LLM.SUMMARY_MODAL.CREATING\"\r\n : \"LLM.SUMMARY_MODAL.REGENERATE\"\r\n ) | translate\r\n }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [":host ::ng-deep .message-body{font-size:14px}:host ::ng-deep .notification-message-container{margin:0 0 16px}:host ::ng-deep .items-container{margin-left:0!important}:host ::ng-deep .text-container{margin-right:0!important}.w-full{width:100%}.llm-summary-actions{display:flex;justify-content:end}.llm-summary-actions-wrapper{display:flex;justify-content:space-between;margin:0 1rem .5rem}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i7.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i7.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i7.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i7.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i8.NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: ["message", "inline"], outputs: ["buttonClicked", "closeClicked", "linkClicked"] }, { kind: "component", type: i9.LLMTextareaComponent, selector: "lib-llm-textarea", inputs: ["text", "disabled", "showErrorMessage"], outputs: ["textEditEvent", "dislikeEvent", "copyEvent"] }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }] }); }
97
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CreateSummaryComponent, selector: "lib-create-summary", ngImport: i0, template: "<h1 mat-dialog-title>{{ \"LLM.SUMMARY_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n <p>{{ \"LLM.SUMMARY_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n <lib-tld-notification-message *ngIf=\"showMissingQuotaMessage\" [message]=\"reachedQuotaMessage\" (closeClicked)=\"missingQuotaMessageClosed = true\"></lib-tld-notification-message>\r\n <lib-tld-notification-message *ngIf=\"showDefaultErrorMessage\" [message]=\"defaultErrorMessage\" (closeClicked)=\"showDefaultErrorMessage = false\"></lib-tld-notification-message>\r\n\r\n <lib-llm-textarea [text]=\"summarizedText !== '' ? summarizedText : initialText\" [disabled]=\"isLoading || !summaryQuotaLeft\" (textEditEvent)=\"textEditEvent($event)\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-summary-actions-wrapper\" mat-dialog-actions>\r\n <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.SUMMARY_MODAL.LIMIT' | translate: { limit: summaryQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-summary-actions\">\r\n <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n {{ \"LLM.SUMMARY_MODAL.CANCEL\" | translate }}\r\n </button>\r\n\r\n <ng-template #closeButton>\r\n <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n {{ \"LLM.SUMMARY_MODAL.CLOSE\" | translate }}\r\n </button>\r\n </ng-template>\r\n \r\n <button\r\n mat-flat-button\r\n color=\"accent\"\r\n (click)=\"createSummary()\"\r\n [disabled]=\"isCreatingDisabled\"\r\n >\r\n {{\r\n (!isSummarized\r\n ? \"LLM.SUMMARY_MODAL.CREATE\"\r\n : \"LLM.SUMMARY_MODAL.REGENERATE\"\r\n ) | translate\r\n }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [":host ::ng-deep .message-body{font-size:14px}:host ::ng-deep .notification-message-container{margin:0 0 16px}:host ::ng-deep .items-container{margin-left:0!important}:host ::ng-deep .text-container{margin-right:0!important}.w-full{width:100%}.llm-summary-actions{display:flex;justify-content:end}.llm-summary-actions-wrapper{display:flex;justify-content:space-between;margin:0 1rem .5rem}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i7.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i7.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i7.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i7.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i8.NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: ["message", "inline"], outputs: ["buttonClicked", "closeClicked", "linkClicked"] }, { kind: "component", type: i9.LLMTextareaComponent, selector: "lib-llm-textarea", inputs: ["text", "disabled"], outputs: ["textEditEvent", "dislikeEvent", "copyEvent"] }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }] }); }
86
98
  }
87
99
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CreateSummaryComponent, decorators: [{
88
100
  type: Component,
89
- args: [{ selector: 'lib-create-summary', template: "<h1 mat-dialog-title>{{ \"LLM.SUMMARY_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n <p>{{ \"LLM.SUMMARY_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n <lib-tld-notification-message *ngIf=\"!summaryQuotaLeft\" [message]=\"reachedQuotaMessage\"></lib-tld-notification-message>\r\n\r\n <lib-llm-textarea [showErrorMessage]=\"showErrorMessage\" [text]=\"text\" [disabled]=\"isLoading || !summaryQuotaLeft\" (textEditEvent)=\"text = $event; checkCharactersLimit()\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-summary-actions-wrapper\" mat-dialog-actions>\r\n <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.SUMMARY_MODAL.LIMIT' | translate: { limit: summaryQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-summary-actions\">\r\n <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n {{ \"LLM.SUMMARY_MODAL.CANCEL\" | translate }}\r\n </button>\r\n\r\n <ng-template #closeButton>\r\n <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n {{ \"LLM.SUMMARY_MODAL.CLOSE\" | translate }}\r\n </button>\r\n </ng-template>\r\n \r\n <button\r\n mat-flat-button\r\n color=\"accent\"\r\n (click)=\"createSummary()\"\r\n [disabled]=\"isCreatingDisabled\"\r\n >\r\n {{\r\n (isLoading\r\n ? \"LLM.SUMMARY_MODAL.CREATING\"\r\n : \"LLM.SUMMARY_MODAL.REGENERATE\"\r\n ) | translate\r\n }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [":host ::ng-deep .message-body{font-size:14px}:host ::ng-deep .notification-message-container{margin:0 0 16px}:host ::ng-deep .items-container{margin-left:0!important}:host ::ng-deep .text-container{margin-right:0!important}.w-full{width:100%}.llm-summary-actions{display:flex;justify-content:end}.llm-summary-actions-wrapper{display:flex;justify-content:space-between;margin:0 1rem .5rem}\n"] }]
101
+ args: [{ selector: 'lib-create-summary', template: "<h1 mat-dialog-title>{{ \"LLM.SUMMARY_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n <p>{{ \"LLM.SUMMARY_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n <lib-tld-notification-message *ngIf=\"showMissingQuotaMessage\" [message]=\"reachedQuotaMessage\" (closeClicked)=\"missingQuotaMessageClosed = true\"></lib-tld-notification-message>\r\n <lib-tld-notification-message *ngIf=\"showDefaultErrorMessage\" [message]=\"defaultErrorMessage\" (closeClicked)=\"showDefaultErrorMessage = false\"></lib-tld-notification-message>\r\n\r\n <lib-llm-textarea [text]=\"summarizedText !== '' ? summarizedText : initialText\" [disabled]=\"isLoading || !summaryQuotaLeft\" (textEditEvent)=\"textEditEvent($event)\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-summary-actions-wrapper\" mat-dialog-actions>\r\n <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.SUMMARY_MODAL.LIMIT' | translate: { limit: summaryQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-summary-actions\">\r\n <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n {{ \"LLM.SUMMARY_MODAL.CANCEL\" | translate }}\r\n </button>\r\n\r\n <ng-template #closeButton>\r\n <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n {{ \"LLM.SUMMARY_MODAL.CLOSE\" | translate }}\r\n </button>\r\n </ng-template>\r\n \r\n <button\r\n mat-flat-button\r\n color=\"accent\"\r\n (click)=\"createSummary()\"\r\n [disabled]=\"isCreatingDisabled\"\r\n >\r\n {{\r\n (!isSummarized\r\n ? \"LLM.SUMMARY_MODAL.CREATE\"\r\n : \"LLM.SUMMARY_MODAL.REGENERATE\"\r\n ) | translate\r\n }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [":host ::ng-deep .message-body{font-size:14px}:host ::ng-deep .notification-message-container{margin:0 0 16px}:host ::ng-deep .items-container{margin-left:0!important}:host ::ng-deep .text-container{margin-right:0!important}.w-full{width:100%}.llm-summary-actions{display:flex;justify-content:end}.llm-summary-actions-wrapper{display:flex;justify-content:space-between;margin:0 1rem .5rem}\n"] }]
90
102
  }], ctorParameters: function () { return [{ type: i1.LLMService }, { type: i2.LLMHelperService }, { type: i3.QuotaService }, { type: i4.PlausibleService }, { type: undefined, decorators: [{
91
103
  type: Inject,
92
104
  args: [MAT_DIALOG_DATA]
93
105
  }] }]; } });
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-summary.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/llm/components/create-summary/create-summary.component.ts","../../../../../../../projects/ngx-common/src/lib/llm/components/create-summary/create-summary.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, OnInit } from '@angular/core';\r\nimport { MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { LLMData } from '../../models/llm-data.model';\r\nimport { LLMService } from '../../services/llm.service';\r\nimport { Subscription, finalize } from 'rxjs';\r\nimport { QuotaService, QuotaType } from '../../../services';\r\nimport { NotificationMessage } from '../../../notification-message';\r\nimport { LLMHelperService } from '../../services/llm-helper.service';\r\nimport { PlausibleService } from '../../services/plausible.service';\r\n\r\n@Component({\r\n  selector: 'lib-create-summary',\r\n  templateUrl: './create-summary.component.html',\r\n  styleUrls: ['./create-summary.component.scss'],\r\n})\r\nexport class CreateSummaryComponent implements OnInit {\r\n  isLoading!: boolean;\r\n  showErrorMessage!: boolean;\r\n  showRemainingQuotaMessage!: boolean;\r\n  isSummarizingCanceled!: boolean;\r\n  isCharactersLimitExceeded!: boolean;\r\n  text!: string;\r\n  language!: string;\r\n  summaryQuotaLeft!: number;\r\n  subscriptionUrl!: string;\r\n\r\n  reachedQuotaMessage!: NotificationMessage;\r\n\r\n  subscription!: Subscription;\r\n\r\n  private readonly trialRequestCount = 15;\r\n  private readonly summaryQuotaLocalStorageKey = 'LLM_SUMMARY_USAGE_KEY';\r\n\r\n  get isCreatingDisabled() {\r\n    return this.isLoading || !this.text || !this.summaryQuotaLeft || this.isCharactersLimitExceeded;\r\n  }\r\n\r\n  constructor(\r\n    private readonly llmService: LLMService,\r\n    private readonly llmHelperService: LLMHelperService,\r\n    private readonly quotaService: QuotaService,\r\n    private readonly plausibleService: PlausibleService,\r\n    @Inject(MAT_DIALOG_DATA) private data: LLMData\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.text = this.data.text;\r\n    this.language = this.data.language;\r\n    this.subscriptionUrl = this.llmService.llmConfiguration.subscriptionUrl;\r\n    this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();\r\n    this.createSummary();\r\n    this.refreshQuota();\r\n  }\r\n\r\n  createSummary(): void {\r\n    this.isLoading = true;\r\n\r\n    this.subscription = this.llmService\r\n      .summarize({ text: this.text, language: this.language })\r\n      .pipe(finalize(() => (this.isLoading = false)))\r\n      .subscribe({\r\n        next: (response) => {\r\n          this.text = response;\r\n          this.showErrorMessage = false;\r\n          this.refreshQuota(true);\r\n        },\r\n        error: () => {\r\n          this.showErrorMessage = true;\r\n        }\r\n      });\r\n  }\r\n\r\n  cancel(): void {\r\n    this.subscription.unsubscribe();\r\n  }\r\n\r\n  copyEvent(): void {\r\n    this.plausibleService.summaryCopyEvent();\r\n  }\r\n  \r\n  dislikeEvent(): void {\r\n    this.plausibleService.summaryDislikeEvent();\r\n  }\r\n\r\n  checkCharactersLimit(): void {\r\n    if (this.text.length > 10000) {\r\n      this.isCharactersLimitExceeded = true;\r\n      return;\r\n    }\r\n\r\n    this.isCharactersLimitExceeded = false;\r\n  }\r\n\r\n  private refreshQuota(decrease?: boolean): void {\r\n    this.quotaService.getQuotaUsage().pipe(finalize(() => this.setQuotaMessage())).subscribe({\r\n      next: (response) => {\r\n        const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_REQUESTS);\r\n\r\n        if (!quota) {\r\n          this.summaryQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(this.summaryQuotaLocalStorageKey, decrease);\r\n          return;\r\n        }\r\n        \r\n        this.summaryQuotaLeft = quota.quotaRemaining;\r\n      },\r\n    });\r\n  }\r\n\r\n  private setQuotaMessage(): void {\r\n    this.showRemainingQuotaMessage = this.summaryQuotaLeft <= this.trialRequestCount;\r\n  }\r\n}\r\n","<h1 mat-dialog-title>{{ \"LLM.SUMMARY_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n  <p>{{ \"LLM.SUMMARY_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n  <lib-tld-notification-message *ngIf=\"!summaryQuotaLeft\" [message]=\"reachedQuotaMessage\"></lib-tld-notification-message>\r\n\r\n  <lib-llm-textarea [showErrorMessage]=\"showErrorMessage\" [text]=\"text\" [disabled]=\"isLoading || !summaryQuotaLeft\" (textEditEvent)=\"text = $event; checkCharactersLimit()\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-summary-actions-wrapper\" mat-dialog-actions>\r\n  <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.SUMMARY_MODAL.LIMIT' | translate: { limit: summaryQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n  <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-summary-actions\">\r\n    <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n      {{ \"LLM.SUMMARY_MODAL.CANCEL\" | translate }}\r\n    </button>\r\n\r\n    <ng-template #closeButton>\r\n      <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n        {{ \"LLM.SUMMARY_MODAL.CLOSE\" | translate }}\r\n      </button>\r\n    </ng-template>\r\n    \r\n    <button\r\n      mat-flat-button\r\n      color=\"accent\"\r\n      (click)=\"createSummary()\"\r\n      [disabled]=\"isCreatingDisabled\"\r\n    >\r\n      {{\r\n        (isLoading\r\n          ? \"LLM.SUMMARY_MODAL.CREATING\"\r\n          : \"LLM.SUMMARY_MODAL.REGENERATE\"\r\n        ) | translate\r\n      }}\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-summary.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/llm/components/create-summary/create-summary.component.ts","../../../../../../../projects/ngx-common/src/lib/llm/components/create-summary/create-summary.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAG3D,OAAO,EAAgB,QAAQ,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAgB,SAAS,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;;;;;AAU5D,MAAM,OAAO,sBAAsB;IAuBjC,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC;IACvE,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,CAAC;IACxD,CAAC;IAED,IAAI,uBAAuB;QACzB,OAAO,CAAC,IAAI,CAAC,gBAAgB,IAAI,CAAC,IAAI,CAAC,yBAAyB,CAAC;IACnE,CAAC;IAED,YACmB,UAAsB,EACtB,gBAAkC,EAClC,YAA0B,EAC1B,gBAAkC,EAClB,IAAa;QAJ7B,eAAU,GAAV,UAAU,CAAY;QACtB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClB,SAAI,GAAJ,IAAI,CAAS;QAxBhD,mBAAc,GAAG,EAAE,CAAC;QACpB,uBAAkB,GAAG,EAAE,CAAC;QAEP,sBAAiB,GAAG,EAAE,CAAC;QAExC,8BAAyB,GAAG,KAAK,CAAC;IAoB/B,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;QACnC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,eAAe,CAAC;QACxE,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,CAAC;QAC1E,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QAEtB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU;aAChC,SAAS,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;aACzH,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC;aAC9C,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;gBACzB,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC;gBAC/B,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;gBAC7B,IAAI,CAAC,uBAAuB,GAAG,KAAK,CAAC;gBACrC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YAC1B,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC;YACtC,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC;IAED,SAAS;QACP,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,CAAC;IAC3C,CAAC;IAED,YAAY;QACV,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,EAAE,CAAC;IAC9C,CAAC;IAED,aAAa,CAAC,IAAY;QACxB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAEO,YAAY,CAAC,QAAkB;QACrC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;YACvF,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE;gBACjB,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,YAAY,CAAC,CAAC;gBAEvF,IAAI,CAAC,KAAK,EAAE;oBACV,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC;oBACxC,OAAO;iBACR;gBAED,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC;YAC/C,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC;YAC1C,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,iBAAiB,CAAC;IACnF,CAAC;IAEO,wBAAwB,CAAC,QAAkB;QACjD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,yBAAyB,CAAC,QAAQ,CAAC,CAAC;IACpF,CAAC;+GAhHU,sBAAsB,wIAwCvB,eAAe;mGAxCd,sBAAsB,0DCfnC,22DAsCA;;4FDvBa,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;;0BA4C3B,MAAM;2BAAC,eAAe","sourcesContent":["import { Component, Inject, OnInit } from '@angular/core';\r\nimport { MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { LLMData } from '../../models/llm-data.model';\r\nimport { LLMService } from '../../services/llm.service';\r\nimport { Subscription, finalize } from 'rxjs';\r\nimport { QuotaService, QuotaType } from '../../../services';\r\nimport { NotificationMessage } from '../../../notification-message';\r\nimport { LLMHelperService } from '../../services/llm-helper.service';\r\nimport { PlausibleService } from '../../services/plausible.service';\r\n\r\n@Component({\r\n  selector: 'lib-create-summary',\r\n  templateUrl: './create-summary.component.html',\r\n  styleUrls: ['./create-summary.component.scss'],\r\n})\r\nexport class CreateSummaryComponent implements OnInit {\r\n  isLoading!: boolean;\r\n  showDefaultErrorMessage!: boolean;\r\n  showRemainingQuotaMessage!: boolean;\r\n  isSummarizingCanceled!: boolean;\r\n  language!: string;\r\n  summaryQuotaLeft!: number;\r\n  subscriptionUrl!: string;\r\n\r\n  reachedQuotaMessage!: NotificationMessage;\r\n\r\n  subscription!: Subscription;\r\n\r\n  isSummarized!: boolean;\r\n\r\n  initialText!: string;\r\n  summarizedText = '';\r\n  manuallyEditedText = '';\r\n\r\n  private readonly trialRequestCount = 15;\r\n\r\n  missingQuotaMessageClosed = false;\r\n\r\n  get isCreatingDisabled() {\r\n    return this.isLoading || !this.initialText || !this.summaryQuotaLeft;\r\n  }\r\n\r\n  get defaultErrorMessage() {\r\n    return this.llmHelperService.getDefaultErrorMessage();\r\n  }\r\n\r\n  get showMissingQuotaMessage() {\r\n    return !this.summaryQuotaLeft && !this.missingQuotaMessageClosed;\r\n  }\r\n\r\n  constructor(\r\n    private readonly llmService: LLMService,\r\n    private readonly llmHelperService: LLMHelperService,\r\n    private readonly quotaService: QuotaService,\r\n    private readonly plausibleService: PlausibleService,\r\n    @Inject(MAT_DIALOG_DATA) private data: LLMData\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.initialText = this.data.text;\r\n    this.language = this.data.language;\r\n    this.subscriptionUrl = this.llmService.llmConfiguration.subscriptionUrl;\r\n    this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();\r\n    this.refreshQuota();\r\n  }\r\n\r\n  createSummary(): void {\r\n    this.isLoading = true;\r\n\r\n    this.subscription = this.llmService\r\n      .summarize({ text: this.manuallyEditedText !== '' ? this.manuallyEditedText : this.initialText, language: this.language })\r\n      .pipe(finalize(() => (this.isLoading = false)))\r\n      .subscribe({\r\n        next: (response) => {\r\n          this.isSummarized = true;\r\n          this.summarizedText = response;\r\n          this.manuallyEditedText = '';\r\n          this.showDefaultErrorMessage = false;\r\n          this.refreshQuota(true);\r\n        },\r\n        error: () => {\r\n          this.showDefaultErrorMessage = true;\r\n        }\r\n      });\r\n  }\r\n\r\n  cancel(): void {\r\n    this.subscription.unsubscribe();\r\n  }\r\n\r\n  copyEvent(): void {\r\n    this.plausibleService.summaryCopyEvent();\r\n  }\r\n  \r\n  dislikeEvent(): void {\r\n    this.plausibleService.summaryDislikeEvent();\r\n  }\r\n\r\n  textEditEvent(text: string): void {\r\n    this.manuallyEditedText = text;\r\n    this.initialText = text;\r\n  }\r\n\r\n  private refreshQuota(decrease?: boolean): void {\r\n    this.quotaService.getQuotaUsage().pipe(finalize(() => this.setQuotaMessage())).subscribe({\r\n      next: (response) => {\r\n        const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_REQUESTS);\r\n\r\n        if (!quota) {\r\n          this.setQuotaFromLocalStorage(decrease);\r\n          return;\r\n        }\r\n        \r\n        this.summaryQuotaLeft = quota.quotaRemaining;\r\n      },\r\n      error: () => {\r\n        this.setQuotaFromLocalStorage(decrease);\r\n      }\r\n    });\r\n  }\r\n\r\n  private setQuotaMessage(): void {\r\n    this.showRemainingQuotaMessage = this.summaryQuotaLeft <= this.trialRequestCount;\r\n  }\r\n\r\n  private setQuotaFromLocalStorage(decrease?: boolean): void {\r\n    this.summaryQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(decrease);          \r\n  }\r\n}\r\n","<h1 mat-dialog-title>{{ \"LLM.SUMMARY_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n  <p>{{ \"LLM.SUMMARY_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n  <lib-tld-notification-message *ngIf=\"showMissingQuotaMessage\" [message]=\"reachedQuotaMessage\" (closeClicked)=\"missingQuotaMessageClosed = true\"></lib-tld-notification-message>\r\n  <lib-tld-notification-message *ngIf=\"showDefaultErrorMessage\" [message]=\"defaultErrorMessage\" (closeClicked)=\"showDefaultErrorMessage = false\"></lib-tld-notification-message>\r\n\r\n  <lib-llm-textarea [text]=\"summarizedText !== '' ? summarizedText : initialText\" [disabled]=\"isLoading || !summaryQuotaLeft\" (textEditEvent)=\"textEditEvent($event)\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-summary-actions-wrapper\" mat-dialog-actions>\r\n  <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.SUMMARY_MODAL.LIMIT' | translate: { limit: summaryQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n  <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-summary-actions\">\r\n    <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n      {{ \"LLM.SUMMARY_MODAL.CANCEL\" | translate }}\r\n    </button>\r\n\r\n    <ng-template #closeButton>\r\n      <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n        {{ \"LLM.SUMMARY_MODAL.CLOSE\" | translate }}\r\n      </button>\r\n    </ng-template>\r\n    \r\n    <button\r\n      mat-flat-button\r\n      color=\"accent\"\r\n      (click)=\"createSummary()\"\r\n      [disabled]=\"isCreatingDisabled\"\r\n    >\r\n      {{\r\n        (!isSummarized\r\n          ? \"LLM.SUMMARY_MODAL.CREATE\"\r\n          : \"LLM.SUMMARY_MODAL.REGENERATE\"\r\n        ) | translate\r\n      }}\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
@@ -20,7 +20,13 @@ import * as i13 from "../../shared/llm-textarea/llm-textarea.component";
20
20
  import * as i14 from "@ngx-translate/core";
21
21
  export class RephraseTranslationComponent {
22
22
  get isRephrasingDisabled() {
23
- return this.isLoading || !this.text || !this.rephraseQuotaLeft || this.isCharactersLimitExceeded;
23
+ return this.isLoading || !this.initialText || !this.rephraseQuotaLeft;
24
+ }
25
+ get defaultErrorMessage() {
26
+ return this.llmHelperService.getDefaultErrorMessage();
27
+ }
28
+ get showMissingQuotaMessage() {
29
+ return !this.rephraseQuotaLeft && !this.missingQuotaMessageClosed;
24
30
  }
25
31
  constructor(llmService, quotaService, llmHelperService, plausibleService, data) {
26
32
  this.llmService = llmService;
@@ -29,29 +35,54 @@ export class RephraseTranslationComponent {
29
35
  this.plausibleService = plausibleService;
30
36
  this.data = data;
31
37
  this.selectedWritingStyle = LLMWritingStyle.GENERAL;
38
+ this.rephrasedText = '';
39
+ this.manuallyEditedText = '';
40
+ this.savedRephrasings = [];
32
41
  this.writingStyles = Object.values(LLMWritingStyle);
33
42
  this.trialRequestCount = 15;
34
- this.rephraseQuotaLocalStorageKey = 'LLM_REPHRASE_USAGE_KEY';
43
+ this.missingQuotaMessageClosed = false;
35
44
  }
36
45
  ngOnInit() {
37
- this.text = this.data.text;
46
+ this.initialText = this.data.text;
38
47
  this.subscriptionUrl = this.llmService.llmConfiguration.subscriptionUrl;
39
48
  this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();
40
49
  this.refreshQuota();
41
50
  }
51
+ checkRephrasedTextSaves() {
52
+ const selectedWritingStyleSave = this.savedRephrasings.find((rephrasing) => rephrasing.style === this.selectedWritingStyle);
53
+ const previousWritingStyleSave = this.savedRephrasings.find((save) => save.style === this.previousWritingStyle);
54
+ if (previousWritingStyleSave) {
55
+ const save = this.savedRephrasings.find((save) => save.style === this.previousWritingStyle);
56
+ if (save) {
57
+ save.text = this.rephrasedText !== '' ? this.rephrasedText : this.initialText;
58
+ }
59
+ }
60
+ else {
61
+ this.savedRephrasings.push({ style: this.previousWritingStyle, text: this.rephrasedText !== '' ? this.rephrasedText : this.initialText });
62
+ }
63
+ this.rephrasedText = selectedWritingStyleSave?.text ?? this.initialText;
64
+ this.manuallyEditedText = '';
65
+ }
66
+ saveWritingStyleBeforeChange(isOpened) {
67
+ if (!isOpened) {
68
+ return;
69
+ }
70
+ this.previousWritingStyle = this.selectedWritingStyle;
71
+ }
42
72
  rephraseText() {
43
73
  this.isLoading = true;
44
74
  this.subscription = this.llmService
45
- .rephrase({ text: this.text, style: this.selectedWritingStyle })
75
+ .rephrase({ text: this.manuallyEditedText !== '' ? this.manuallyEditedText : this.initialText, style: this.selectedWritingStyle })
46
76
  .pipe(finalize(() => (this.isLoading = false)))
47
77
  .subscribe({
48
78
  next: (response) => {
49
- this.text = response;
50
- this.showErrorMessage = false;
79
+ this.rephrasedText = response;
80
+ this.manuallyEditedText = '';
81
+ this.showDefaultErrorMessage = false;
51
82
  this.refreshQuota(true);
52
83
  },
53
84
  error: () => {
54
- this.showErrorMessage = true;
85
+ this.showDefaultErrorMessage = true;
55
86
  }
56
87
  });
57
88
  }
@@ -64,36 +95,40 @@ export class RephraseTranslationComponent {
64
95
  dislikeEvent() {
65
96
  this.plausibleService.rephraseDislikeEvent();
66
97
  }
67
- checkCharactersLimit() {
68
- if (this.text.length > 10000) {
69
- this.isCharactersLimitExceeded = true;
70
- return;
71
- }
72
- this.isCharactersLimitExceeded = false;
98
+ textEditEvent(text) {
99
+ this.manuallyEditedText = text;
100
+ this.initialText = text;
101
+ this.rephrasedText = '';
73
102
  }
74
103
  refreshQuota(decrease) {
75
104
  this.quotaService.getQuotaUsage().pipe(finalize(() => this.setQuotaMessage())).subscribe({
76
105
  next: (response) => {
77
106
  const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_CHARACTER_COUNT);
78
107
  if (!quota) {
79
- this.rephraseQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(this.rephraseQuotaLocalStorageKey, decrease);
108
+ this.setQuotaFromLocalStorage(decrease);
80
109
  return;
81
110
  }
82
111
  this.rephraseQuotaLeft = quota.quotaRemaining;
83
112
  },
113
+ error: () => {
114
+ this.setQuotaFromLocalStorage(decrease);
115
+ }
84
116
  });
85
117
  }
86
118
  setQuotaMessage() {
87
119
  this.showRemainingQuotaMessage = this.rephraseQuotaLeft <= this.trialRequestCount;
88
120
  }
121
+ setQuotaFromLocalStorage(decrease) {
122
+ this.rephraseQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(decrease);
123
+ }
89
124
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RephraseTranslationComponent, deps: [{ token: i1.LLMService }, { token: i2.QuotaService }, { token: i3.LLMHelperService }, { token: i4.PlausibleService }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
90
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RephraseTranslationComponent, selector: "lib-rephrase-translation", ngImport: i0, template: "<h1 mat-dialog-title>{{ \"LLM.REPHRASE_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n <p>{{ \"LLM.REPHRASE_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n <lib-tld-notification-message *ngIf=\"!rephraseQuotaLeft\" [message]=\"reachedQuotaMessage\"></lib-tld-notification-message>\r\n\r\n <mat-form-field color=\"accent\" class=\"w-full llm-writing-style-select\" appearance=\"outline\">\r\n <mat-label>{{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.TITLE' | translate }}</mat-label>\r\n <mat-select [(value)]=\"selectedWritingStyle\">\r\n <mat-option *ngFor=\"let style of writingStyles\" [value]=\"style\">\r\n {{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (style | uppercase) | translate }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <p class=\"llm-writing-style text-m-semi-bold\">{{\r\n \"LLM.REPHRASE_MODAL.WRITING_STYLES.SPECIFIC_STYLE\" | translate : \r\n { style: 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (selectedWritingStyle | uppercase) | translate } \r\n }}\r\n <span\r\n class=\"material-icons-outlined info-icon\"\r\n matTooltipClass=\"multiline-tooltip\"\r\n matTooltipPosition=\"above\" \r\n [matTooltip]=\"'LLM.REPHRASE_MODAL.WRITING_STYLES.TOOLTIP_' + (selectedWritingStyle | uppercase) | translate\" \r\n >\r\n info\r\n </span>\r\n </p>\r\n\r\n <lib-llm-textarea [text]=\"text\" [disabled]=\"isLoading || !rephraseQuotaLeft\" [showErrorMessage]=\"showErrorMessage\" (textEditEvent)=\"text = $event; checkCharactersLimit()\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-rephrase-actions-wrapper\" mat-dialog-actions>\r\n <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.REPHRASE_MODAL.LIMIT' | translate: { limit: rephraseQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-rephrase-actions\">\r\n <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n {{ \"LLM.REPHRASE_MODAL.CANCEL\" | translate }}\r\n </button>\r\n\r\n <ng-template #closeButton>\r\n <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n {{ \"LLM.REPHRASE_MODAL.CLOSE\" | translate }}\r\n </button>\r\n </ng-template>\r\n \r\n <button\r\n mat-flat-button\r\n color=\"accent\"\r\n (click)=\"rephraseText()\"\r\n [disabled]=\"isRephrasingDisabled\"\r\n >\r\n {{\r\n (isLoading\r\n ? \"LLM.REPHRASE_MODAL.REPHRASING\"\r\n : \"LLM.REPHRASE_MODAL.REPHRASE\"\r\n ) | translate\r\n }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".info-icon{font-size:1rem;margin-left:5px}:host ::ng-deep .message-body{font-size:14px}:host ::ng-deep .notification-message-container{margin:0 0 16px}:host ::ng-deep .items-container{margin-left:0!important}:host ::ng-deep .text-container{margin-right:0!important}::ng-deep .multiline-tooltip{white-space:pre;min-width:-moz-fit-content;min-width:fit-content}::ng-deep .multiline-tooltip .mdc-tooltip__surface{max-width:none!important}.llm-writing-style-select{margin-top:1.25rem}.llm-writing-style{display:flex;align-items:center;margin-bottom:.25rem}.llm-rephrase-actions-wrapper{display:flex;justify-content:space-between;margin:0 1rem .5rem}.llm-rephrase-actions{display:flex;justify-content:end}.w-full{width:100%}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i7.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i7.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i7.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i7.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i8.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i8.MatLabel, selector: "mat-label" }, { kind: "component", type: i9.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i10.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i11.NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: ["message", "inline"], outputs: ["buttonClicked", "closeClicked", "linkClicked"] }, { kind: "directive", type: i12.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i13.LLMTextareaComponent, selector: "lib-llm-textarea", inputs: ["text", "disabled", "showErrorMessage"], outputs: ["textEditEvent", "dislikeEvent", "copyEvent"] }, { kind: "pipe", type: i5.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }] }); }
125
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RephraseTranslationComponent, selector: "lib-rephrase-translation", ngImport: i0, template: "<h1 mat-dialog-title>{{ \"LLM.REPHRASE_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n <p>{{ \"LLM.REPHRASE_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n <lib-tld-notification-message *ngIf=\"showMissingQuotaMessage\" [message]=\"reachedQuotaMessage\" (closeClicked)=\"missingQuotaMessageClosed = true\"></lib-tld-notification-message>\r\n <lib-tld-notification-message *ngIf=\"showDefaultErrorMessage\" [message]=\"defaultErrorMessage\" (closeClicked)=\"showDefaultErrorMessage = false\"></lib-tld-notification-message>\r\n\r\n <mat-form-field color=\"accent\" class=\"w-full llm-writing-style-select\" appearance=\"outline\">\r\n <mat-label>{{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.TITLE' | translate }}</mat-label>\r\n <mat-select (openedChange)=\"saveWritingStyleBeforeChange($event)\" (selectionChange)=\"checkRephrasedTextSaves()\" [(value)]=\"selectedWritingStyle\">\r\n <mat-option *ngFor=\"let style of writingStyles\" [value]=\"style\">\r\n {{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (style | uppercase) | translate }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <p class=\"llm-writing-style text-m-semi-bold\">{{\r\n \"LLM.REPHRASE_MODAL.WRITING_STYLES.SPECIFIC_STYLE\" | translate : \r\n { style: 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (selectedWritingStyle | uppercase) | translate } \r\n }}\r\n <span\r\n class=\"material-icons-outlined info-icon\"\r\n matTooltipClass=\"multiline-tooltip\"\r\n matTooltipPosition=\"above\" \r\n [matTooltip]=\"'LLM.REPHRASE_MODAL.WRITING_STYLES.TOOLTIP_' + (selectedWritingStyle | uppercase) | translate\" \r\n >\r\n info\r\n </span>\r\n </p>\r\n\r\n <lib-llm-textarea [text]=\"rephrasedText !== '' ? rephrasedText : initialText\" [disabled]=\"isLoading || !rephraseQuotaLeft\" (textEditEvent)=\"textEditEvent($event)\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-rephrase-actions-wrapper\" mat-dialog-actions>\r\n <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.REPHRASE_MODAL.LIMIT' | translate: { limit: rephraseQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-rephrase-actions\">\r\n <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n {{ \"LLM.REPHRASE_MODAL.CANCEL\" | translate }}\r\n </button>\r\n\r\n <ng-template #closeButton>\r\n <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n {{ \"LLM.REPHRASE_MODAL.CLOSE\" | translate }}\r\n </button>\r\n </ng-template>\r\n \r\n <button\r\n mat-flat-button\r\n color=\"accent\"\r\n (click)=\"rephraseText()\"\r\n [disabled]=\"isRephrasingDisabled\"\r\n >\r\n {{ \"LLM.REPHRASE_MODAL.REPHRASE\" | translate }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".info-icon{font-size:1rem;margin-left:5px}:host ::ng-deep .message-body{font-size:14px}:host ::ng-deep .notification-message-container{margin:0 0 16px}:host ::ng-deep .items-container{margin-left:0!important}:host ::ng-deep .text-container{margin-right:0!important}::ng-deep .multiline-tooltip{white-space:pre;min-width:-moz-fit-content;min-width:fit-content}::ng-deep .multiline-tooltip .mdc-tooltip__surface{max-width:none!important}.llm-writing-style-select{margin-top:1.25rem}.llm-writing-style{display:flex;align-items:center;margin-bottom:.25rem}.llm-rephrase-actions-wrapper{display:flex;justify-content:space-between;margin:0 1rem .5rem}.llm-rephrase-actions{display:flex;justify-content:end}.w-full{width:100%}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i7.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i7.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i7.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i7.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i8.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i8.MatLabel, selector: "mat-label" }, { kind: "component", type: i9.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i10.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i11.NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: ["message", "inline"], outputs: ["buttonClicked", "closeClicked", "linkClicked"] }, { kind: "directive", type: i12.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i13.LLMTextareaComponent, selector: "lib-llm-textarea", inputs: ["text", "disabled"], outputs: ["textEditEvent", "dislikeEvent", "copyEvent"] }, { kind: "pipe", type: i5.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }] }); }
91
126
  }
92
127
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RephraseTranslationComponent, decorators: [{
93
128
  type: Component,
94
- args: [{ selector: 'lib-rephrase-translation', template: "<h1 mat-dialog-title>{{ \"LLM.REPHRASE_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n <p>{{ \"LLM.REPHRASE_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n <lib-tld-notification-message *ngIf=\"!rephraseQuotaLeft\" [message]=\"reachedQuotaMessage\"></lib-tld-notification-message>\r\n\r\n <mat-form-field color=\"accent\" class=\"w-full llm-writing-style-select\" appearance=\"outline\">\r\n <mat-label>{{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.TITLE' | translate }}</mat-label>\r\n <mat-select [(value)]=\"selectedWritingStyle\">\r\n <mat-option *ngFor=\"let style of writingStyles\" [value]=\"style\">\r\n {{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (style | uppercase) | translate }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <p class=\"llm-writing-style text-m-semi-bold\">{{\r\n \"LLM.REPHRASE_MODAL.WRITING_STYLES.SPECIFIC_STYLE\" | translate : \r\n { style: 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (selectedWritingStyle | uppercase) | translate } \r\n }}\r\n <span\r\n class=\"material-icons-outlined info-icon\"\r\n matTooltipClass=\"multiline-tooltip\"\r\n matTooltipPosition=\"above\" \r\n [matTooltip]=\"'LLM.REPHRASE_MODAL.WRITING_STYLES.TOOLTIP_' + (selectedWritingStyle | uppercase) | translate\" \r\n >\r\n info\r\n </span>\r\n </p>\r\n\r\n <lib-llm-textarea [text]=\"text\" [disabled]=\"isLoading || !rephraseQuotaLeft\" [showErrorMessage]=\"showErrorMessage\" (textEditEvent)=\"text = $event; checkCharactersLimit()\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-rephrase-actions-wrapper\" mat-dialog-actions>\r\n <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.REPHRASE_MODAL.LIMIT' | translate: { limit: rephraseQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-rephrase-actions\">\r\n <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n {{ \"LLM.REPHRASE_MODAL.CANCEL\" | translate }}\r\n </button>\r\n\r\n <ng-template #closeButton>\r\n <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n {{ \"LLM.REPHRASE_MODAL.CLOSE\" | translate }}\r\n </button>\r\n </ng-template>\r\n \r\n <button\r\n mat-flat-button\r\n color=\"accent\"\r\n (click)=\"rephraseText()\"\r\n [disabled]=\"isRephrasingDisabled\"\r\n >\r\n {{\r\n (isLoading\r\n ? \"LLM.REPHRASE_MODAL.REPHRASING\"\r\n : \"LLM.REPHRASE_MODAL.REPHRASE\"\r\n ) | translate\r\n }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".info-icon{font-size:1rem;margin-left:5px}:host ::ng-deep .message-body{font-size:14px}:host ::ng-deep .notification-message-container{margin:0 0 16px}:host ::ng-deep .items-container{margin-left:0!important}:host ::ng-deep .text-container{margin-right:0!important}::ng-deep .multiline-tooltip{white-space:pre;min-width:-moz-fit-content;min-width:fit-content}::ng-deep .multiline-tooltip .mdc-tooltip__surface{max-width:none!important}.llm-writing-style-select{margin-top:1.25rem}.llm-writing-style{display:flex;align-items:center;margin-bottom:.25rem}.llm-rephrase-actions-wrapper{display:flex;justify-content:space-between;margin:0 1rem .5rem}.llm-rephrase-actions{display:flex;justify-content:end}.w-full{width:100%}\n"] }]
129
+ args: [{ selector: 'lib-rephrase-translation', template: "<h1 mat-dialog-title>{{ \"LLM.REPHRASE_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n <p>{{ \"LLM.REPHRASE_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n <lib-tld-notification-message *ngIf=\"showMissingQuotaMessage\" [message]=\"reachedQuotaMessage\" (closeClicked)=\"missingQuotaMessageClosed = true\"></lib-tld-notification-message>\r\n <lib-tld-notification-message *ngIf=\"showDefaultErrorMessage\" [message]=\"defaultErrorMessage\" (closeClicked)=\"showDefaultErrorMessage = false\"></lib-tld-notification-message>\r\n\r\n <mat-form-field color=\"accent\" class=\"w-full llm-writing-style-select\" appearance=\"outline\">\r\n <mat-label>{{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.TITLE' | translate }}</mat-label>\r\n <mat-select (openedChange)=\"saveWritingStyleBeforeChange($event)\" (selectionChange)=\"checkRephrasedTextSaves()\" [(value)]=\"selectedWritingStyle\">\r\n <mat-option *ngFor=\"let style of writingStyles\" [value]=\"style\">\r\n {{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (style | uppercase) | translate }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <p class=\"llm-writing-style text-m-semi-bold\">{{\r\n \"LLM.REPHRASE_MODAL.WRITING_STYLES.SPECIFIC_STYLE\" | translate : \r\n { style: 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (selectedWritingStyle | uppercase) | translate } \r\n }}\r\n <span\r\n class=\"material-icons-outlined info-icon\"\r\n matTooltipClass=\"multiline-tooltip\"\r\n matTooltipPosition=\"above\" \r\n [matTooltip]=\"'LLM.REPHRASE_MODAL.WRITING_STYLES.TOOLTIP_' + (selectedWritingStyle | uppercase) | translate\" \r\n >\r\n info\r\n </span>\r\n </p>\r\n\r\n <lib-llm-textarea [text]=\"rephrasedText !== '' ? rephrasedText : initialText\" [disabled]=\"isLoading || !rephraseQuotaLeft\" (textEditEvent)=\"textEditEvent($event)\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-rephrase-actions-wrapper\" mat-dialog-actions>\r\n <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.REPHRASE_MODAL.LIMIT' | translate: { limit: rephraseQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-rephrase-actions\">\r\n <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n {{ \"LLM.REPHRASE_MODAL.CANCEL\" | translate }}\r\n </button>\r\n\r\n <ng-template #closeButton>\r\n <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n {{ \"LLM.REPHRASE_MODAL.CLOSE\" | translate }}\r\n </button>\r\n </ng-template>\r\n \r\n <button\r\n mat-flat-button\r\n color=\"accent\"\r\n (click)=\"rephraseText()\"\r\n [disabled]=\"isRephrasingDisabled\"\r\n >\r\n {{ \"LLM.REPHRASE_MODAL.REPHRASE\" | translate }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".info-icon{font-size:1rem;margin-left:5px}:host ::ng-deep .message-body{font-size:14px}:host ::ng-deep .notification-message-container{margin:0 0 16px}:host ::ng-deep .items-container{margin-left:0!important}:host ::ng-deep .text-container{margin-right:0!important}::ng-deep .multiline-tooltip{white-space:pre;min-width:-moz-fit-content;min-width:fit-content}::ng-deep .multiline-tooltip .mdc-tooltip__surface{max-width:none!important}.llm-writing-style-select{margin-top:1.25rem}.llm-writing-style{display:flex;align-items:center;margin-bottom:.25rem}.llm-rephrase-actions-wrapper{display:flex;justify-content:space-between;margin:0 1rem .5rem}.llm-rephrase-actions{display:flex;justify-content:end}.w-full{width:100%}\n"] }]
95
130
  }], ctorParameters: function () { return [{ type: i1.LLMService }, { type: i2.QuotaService }, { type: i3.LLMHelperService }, { type: i4.PlausibleService }, { type: undefined, decorators: [{
96
131
  type: Inject,
97
132
  args: [MAT_DIALOG_DATA]
98
133
  }] }]; } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rephrase-translation.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/llm/components/rephrase-translation/rephrase-translation.component.ts","../../../../../../../projects/ngx-common/src/lib/llm/components/rephrase-translation/rephrase-translation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, OnInit } from '@angular/core';\r\nimport { LLMService } from '../../services/llm.service';\r\nimport { QuotaService, QuotaType } from '../../../services';\r\nimport { LLMData } from '../../models/llm-data.model';\r\nimport { MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { Subscription, finalize } from 'rxjs';\r\nimport { LLMWritingStyle } from '../../models/llm-writing-style.enum';\r\nimport { NotificationMessage } from '../../../notification-message';\r\nimport { LLMHelperService } from '../../services/llm-helper.service';\r\nimport { PlausibleService } from '../../services/plausible.service';\r\n\r\n@Component({\r\n  selector: 'lib-rephrase-translation',\r\n  templateUrl: './rephrase-translation.component.html',\r\n  styleUrls: ['./rephrase-translation.component.scss']\r\n})\r\nexport class RephraseTranslationComponent implements OnInit {\r\n  isLoading!: boolean;\r\n  showErrorMessage!: boolean;\r\n  showRemainingQuotaMessage!: boolean;\r\n  isRephraseCanceled!: boolean;\r\n  text!: string;\r\n  rephraseQuotaLeft!: number;\r\n  subscriptionUrl!: string;\r\n  selectedWritingStyle = LLMWritingStyle.GENERAL;\r\n  isCharactersLimitExceeded!: boolean;\r\n\r\n  reachedQuotaMessage!: NotificationMessage;\r\n\r\n  subscription!: Subscription;\r\n  \r\n  readonly writingStyles = Object.values(LLMWritingStyle);\r\n\r\n  private readonly trialRequestCount = 15;\r\n  private readonly rephraseQuotaLocalStorageKey = 'LLM_REPHRASE_USAGE_KEY';\r\n\r\n  get isRephrasingDisabled() {\r\n    return this.isLoading || !this.text || !this.rephraseQuotaLeft || this.isCharactersLimitExceeded\r\n  }\r\n\r\n  constructor(\r\n    private readonly llmService: LLMService,\r\n    private readonly quotaService: QuotaService,\r\n    private readonly llmHelperService: LLMHelperService,\r\n    private readonly plausibleService: PlausibleService,\r\n    @Inject(MAT_DIALOG_DATA) private data: LLMData\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.text = this.data.text;\r\n    this.subscriptionUrl = this.llmService.llmConfiguration.subscriptionUrl;\r\n    this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();\r\n    this.refreshQuota();\r\n  }\r\n\r\n  rephraseText(): void {\r\n    this.isLoading = true;\r\n\r\n    this.subscription = this.llmService\r\n      .rephrase({ text: this.text, style: this.selectedWritingStyle })\r\n      .pipe(finalize(() => (this.isLoading = false)))\r\n      .subscribe({\r\n        next: (response) => {\r\n          this.text = response;\r\n          this.showErrorMessage = false;\r\n          this.refreshQuota(true);\r\n        },\r\n        error: () => {\r\n          this.showErrorMessage = true;\r\n        }\r\n      });\r\n  }\r\n\r\n  cancel(): void {\r\n    this.subscription.unsubscribe();\r\n  }\r\n\r\n  copyEvent(): void {\r\n    this.plausibleService.rephraseCopyEvent();\r\n  }\r\n  \r\n  dislikeEvent(): void {\r\n    this.plausibleService.rephraseDislikeEvent();\r\n  }\r\n\r\n  checkCharactersLimit(): void {\r\n    if (this.text.length > 10000) {\r\n      this.isCharactersLimitExceeded = true;\r\n      return;\r\n    }\r\n\r\n    this.isCharactersLimitExceeded = false;\r\n  }\r\n\r\n  private refreshQuota(decrease?: boolean): void {\r\n    this.quotaService.getQuotaUsage().pipe(finalize(() => this.setQuotaMessage())).subscribe({\r\n      next: (response) => {\r\n        const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_CHARACTER_COUNT);\r\n\r\n        if (!quota) {\r\n          this.rephraseQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(this.rephraseQuotaLocalStorageKey, decrease);          \r\n          return;\r\n        }\r\n\r\n        this.rephraseQuotaLeft = quota.quotaRemaining;\r\n      },\r\n    });\r\n  }\r\n\r\n  private setQuotaMessage(): void {\r\n    this.showRemainingQuotaMessage = this.rephraseQuotaLeft <= this.trialRequestCount;\r\n  }\r\n}\r\n","<h1 mat-dialog-title>{{ \"LLM.REPHRASE_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n  <p>{{ \"LLM.REPHRASE_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n  <lib-tld-notification-message *ngIf=\"!rephraseQuotaLeft\" [message]=\"reachedQuotaMessage\"></lib-tld-notification-message>\r\n\r\n  <mat-form-field color=\"accent\" class=\"w-full llm-writing-style-select\" appearance=\"outline\">\r\n    <mat-label>{{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.TITLE' | translate }}</mat-label>\r\n    <mat-select [(value)]=\"selectedWritingStyle\">\r\n      <mat-option *ngFor=\"let style of writingStyles\" [value]=\"style\">\r\n        {{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (style | uppercase) | translate }}\r\n      </mat-option>\r\n    </mat-select>\r\n  </mat-form-field>\r\n\r\n  <p class=\"llm-writing-style text-m-semi-bold\">{{\r\n      \"LLM.REPHRASE_MODAL.WRITING_STYLES.SPECIFIC_STYLE\" | translate : \r\n      { style: 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (selectedWritingStyle | uppercase) | translate } \r\n    }}\r\n    <span\r\n      class=\"material-icons-outlined info-icon\"\r\n      matTooltipClass=\"multiline-tooltip\"\r\n      matTooltipPosition=\"above\" \r\n      [matTooltip]=\"'LLM.REPHRASE_MODAL.WRITING_STYLES.TOOLTIP_' + (selectedWritingStyle | uppercase) | translate\" \r\n    >\r\n      info\r\n    </span>\r\n  </p>\r\n\r\n  <lib-llm-textarea [text]=\"text\" [disabled]=\"isLoading || !rephraseQuotaLeft\" [showErrorMessage]=\"showErrorMessage\" (textEditEvent)=\"text = $event; checkCharactersLimit()\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-rephrase-actions-wrapper\" mat-dialog-actions>\r\n  <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.REPHRASE_MODAL.LIMIT' | translate: { limit: rephraseQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n  <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-rephrase-actions\">\r\n    <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n      {{ \"LLM.REPHRASE_MODAL.CANCEL\" | translate }}\r\n    </button>\r\n\r\n    <ng-template #closeButton>\r\n      <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n        {{ \"LLM.REPHRASE_MODAL.CLOSE\" | translate }}\r\n      </button>\r\n    </ng-template>\r\n    \r\n    <button\r\n      mat-flat-button\r\n      color=\"accent\"\r\n      (click)=\"rephraseText()\"\r\n      [disabled]=\"isRephrasingDisabled\"\r\n    >\r\n      {{\r\n        (isLoading\r\n          ? \"LLM.REPHRASE_MODAL.REPHRASING\"\r\n          : \"LLM.REPHRASE_MODAL.REPHRASE\"\r\n        ) | translate\r\n      }}\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rephrase-translation.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/llm/components/rephrase-translation/rephrase-translation.component.ts","../../../../../../../projects/ngx-common/src/lib/llm/components/rephrase-translation/rephrase-translation.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAE1D,OAAO,EAAgB,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE5D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAgB,QAAQ,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;;;;;;;;AAUtE,MAAM,OAAO,4BAA4B;IA0BvC,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC;IACxE,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,CAAC;IACxD,CAAC;IAED,IAAI,uBAAuB;QACzB,OAAO,CAAC,IAAI,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,yBAAyB,CAAC;IACpE,CAAC;IAED,YACmB,UAAsB,EACtB,YAA0B,EAC1B,gBAAkC,EAClC,gBAAkC,EAClB,IAAa;QAJ7B,eAAU,GAAV,UAAU,CAAY;QACtB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClB,SAAI,GAAJ,IAAI,CAAS;QAnChD,yBAAoB,GAAG,eAAe,CAAC,OAAO,CAAC;QAO/C,kBAAa,GAAG,EAAE,CAAC;QACnB,uBAAkB,GAAG,EAAE,CAAC;QAEhB,qBAAgB,GAA6C,EAAE,CAAC;QAE/D,kBAAa,GAAG,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QAEvC,sBAAiB,GAAG,EAAE,CAAC;QAExC,8BAAyB,GAAG,KAAK,CAAC;IAoB/B,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;QAClC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,eAAe,CAAC;QACxE,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,CAAC;QAC1E,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,uBAAuB;QACrB,MAAM,wBAAwB,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,KAAK,KAAK,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAC5H,MAAM,wBAAwB,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAEhH,IAAI,wBAAwB,EAAE;YAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,oBAAoB,CAAC,CAAC;YAC5F,IAAI,IAAI,EAAE;gBACR,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;aAC/E;SACF;aAAM;YACL,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,oBAAoB,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;SAC3I;QAED,IAAI,CAAC,aAAa,GAAG,wBAAwB,EAAE,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC;QACxE,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;IAC/B,CAAC;IAED,4BAA4B,CAAC,QAAiB;QAC5C,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO;SACR;QAED,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC;IACxD,CAAC;IAED,YAAY;QACV,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QAEtB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU;aAChC,QAAQ,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,IAAI,CAAC,oBAAoB,EAAE,CAAC;aACjI,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC;aAC9C,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;gBAC9B,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;gBAC7B,IAAI,CAAC,uBAAuB,GAAG,KAAK,CAAC;gBACrC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YAC1B,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC;YACtC,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC;IAED,SAAS;QACP,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;IAC5C,CAAC;IAED,YAAY;QACV,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,EAAE,CAAC;IAC/C,CAAC;IAED,aAAa,CAAC,IAAY;QACxB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC1B,CAAC;IAEO,YAAY,CAAC,QAAkB;QACrC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;YACvF,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE;gBACjB,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,mBAAmB,CAAC,CAAC;gBAE9F,IAAI,CAAC,KAAK,EAAE;oBACV,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC;oBACxC,OAAO;iBACR;gBAED,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,cAAc,CAAC;YAChD,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC;YAC1C,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC;IACpF,CAAC;IAEO,wBAAwB,CAAC,QAAkB;QACjD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,gBAAgB,CAAC,yBAAyB,CAAC,QAAQ,CAAC,CAAC;IACrF,CAAC;+GA3IU,4BAA4B,wIA2C7B,eAAe;mGA3Cd,4BAA4B,gEChBzC,o5FAwDA;;4FDxCa,4BAA4B;kBALxC,SAAS;+BACE,0BAA0B;;0BA+CjC,MAAM;2BAAC,eAAe","sourcesContent":["import { Component, Inject, OnInit } from '@angular/core';\r\nimport { LLMService } from '../../services/llm.service';\r\nimport { QuotaService, QuotaType } from '../../../services';\r\nimport { LLMData } from '../../models/llm-data.model';\r\nimport { MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { Subscription, finalize } from 'rxjs';\r\nimport { LLMWritingStyle } from '../../models/llm-writing-style.enum';\r\nimport { NotificationMessage } from '../../../notification-message';\r\nimport { LLMHelperService } from '../../services/llm-helper.service';\r\nimport { PlausibleService } from '../../services/plausible.service';\r\n\r\n@Component({\r\n  selector: 'lib-rephrase-translation',\r\n  templateUrl: './rephrase-translation.component.html',\r\n  styleUrls: ['./rephrase-translation.component.scss']\r\n})\r\nexport class RephraseTranslationComponent implements OnInit {\r\n  isLoading!: boolean;\r\n  showDefaultErrorMessage!: boolean;\r\n  showRemainingQuotaMessage!: boolean;\r\n  isRephraseCanceled!: boolean;\r\n  rephraseQuotaLeft!: number;\r\n  subscriptionUrl!: string;\r\n  previousWritingStyle!: LLMWritingStyle;\r\n  selectedWritingStyle = LLMWritingStyle.GENERAL;\r\n\r\n  reachedQuotaMessage!: NotificationMessage;\r\n\r\n  subscription!: Subscription;\r\n\r\n  initialText!: string;\r\n  rephrasedText = '';\r\n  manuallyEditedText = '';\r\n\r\n  private savedRephrasings: {style: LLMWritingStyle, text: string}[] = [];\r\n  \r\n  readonly writingStyles = Object.values(LLMWritingStyle);\r\n\r\n  private readonly trialRequestCount = 15;\r\n\r\n  missingQuotaMessageClosed = false;\r\n\r\n  get isRephrasingDisabled() {\r\n    return this.isLoading || !this.initialText || !this.rephraseQuotaLeft;\r\n  }\r\n\r\n  get defaultErrorMessage() {\r\n    return this.llmHelperService.getDefaultErrorMessage();\r\n  }\r\n\r\n  get showMissingQuotaMessage() {\r\n    return !this.rephraseQuotaLeft && !this.missingQuotaMessageClosed;\r\n  }\r\n\r\n  constructor(\r\n    private readonly llmService: LLMService,\r\n    private readonly quotaService: QuotaService,\r\n    private readonly llmHelperService: LLMHelperService,\r\n    private readonly plausibleService: PlausibleService,\r\n    @Inject(MAT_DIALOG_DATA) private data: LLMData\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.initialText = this.data.text;\r\n    this.subscriptionUrl = this.llmService.llmConfiguration.subscriptionUrl;\r\n    this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();\r\n    this.refreshQuota();\r\n  }\r\n\r\n  checkRephrasedTextSaves(): void {\r\n    const selectedWritingStyleSave = this.savedRephrasings.find((rephrasing) => rephrasing.style === this.selectedWritingStyle);\r\n    const previousWritingStyleSave = this.savedRephrasings.find((save) => save.style === this.previousWritingStyle);\r\n    \r\n    if (previousWritingStyleSave) {\r\n      const save = this.savedRephrasings.find((save) => save.style === this.previousWritingStyle);\r\n      if (save) {\r\n        save.text = this.rephrasedText !== '' ? this.rephrasedText : this.initialText;\r\n      }\r\n    } else {\r\n      this.savedRephrasings.push({ style: this.previousWritingStyle, text: this.rephrasedText !== '' ? this.rephrasedText : this.initialText });\r\n    }\r\n    \r\n    this.rephrasedText = selectedWritingStyleSave?.text ?? this.initialText;\r\n    this.manuallyEditedText = '';\r\n  }\r\n\r\n  saveWritingStyleBeforeChange(isOpened: boolean): void {\r\n    if (!isOpened) {\r\n      return;\r\n    }\r\n\r\n    this.previousWritingStyle = this.selectedWritingStyle;\r\n  }\r\n\r\n  rephraseText(): void {\r\n    this.isLoading = true;\r\n\r\n    this.subscription = this.llmService\r\n      .rephrase({ text: this.manuallyEditedText !== '' ? this.manuallyEditedText : this.initialText, style: this.selectedWritingStyle })\r\n      .pipe(finalize(() => (this.isLoading = false)))\r\n      .subscribe({\r\n        next: (response) => {\r\n          this.rephrasedText = response;\r\n          this.manuallyEditedText = '';\r\n          this.showDefaultErrorMessage = false;\r\n          this.refreshQuota(true);\r\n        },\r\n        error: () => {\r\n          this.showDefaultErrorMessage = true;\r\n        }\r\n      });\r\n  }\r\n\r\n  cancel(): void {\r\n    this.subscription.unsubscribe();\r\n  }\r\n\r\n  copyEvent(): void {\r\n    this.plausibleService.rephraseCopyEvent();\r\n  }\r\n  \r\n  dislikeEvent(): void {\r\n    this.plausibleService.rephraseDislikeEvent();\r\n  }\r\n\r\n  textEditEvent(text: string): void {\r\n    this.manuallyEditedText = text;\r\n    this.initialText = text;\r\n    this.rephrasedText = '';\r\n  }\r\n\r\n  private refreshQuota(decrease?: boolean): void {\r\n    this.quotaService.getQuotaUsage().pipe(finalize(() => this.setQuotaMessage())).subscribe({\r\n      next: (response) => {\r\n        const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_CHARACTER_COUNT);\r\n\r\n        if (!quota) {\r\n          this.setQuotaFromLocalStorage(decrease);\r\n          return;\r\n        }\r\n\r\n        this.rephraseQuotaLeft = quota.quotaRemaining;\r\n      },\r\n      error: () => {\r\n        this.setQuotaFromLocalStorage(decrease);\r\n      }\r\n    });\r\n  }\r\n\r\n  private setQuotaMessage(): void {\r\n    this.showRemainingQuotaMessage = this.rephraseQuotaLeft <= this.trialRequestCount;\r\n  }\r\n\r\n  private setQuotaFromLocalStorage(decrease?: boolean): void {\r\n    this.rephraseQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(decrease);          \r\n  }\r\n}\r\n","<h1 mat-dialog-title>{{ \"LLM.REPHRASE_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n  <p>{{ \"LLM.REPHRASE_MODAL.DESCRIPTION\" | translate }}</p>\r\n\r\n  <lib-tld-notification-message *ngIf=\"showMissingQuotaMessage\" [message]=\"reachedQuotaMessage\" (closeClicked)=\"missingQuotaMessageClosed = true\"></lib-tld-notification-message>\r\n  <lib-tld-notification-message *ngIf=\"showDefaultErrorMessage\" [message]=\"defaultErrorMessage\" (closeClicked)=\"showDefaultErrorMessage = false\"></lib-tld-notification-message>\r\n\r\n  <mat-form-field color=\"accent\" class=\"w-full llm-writing-style-select\" appearance=\"outline\">\r\n    <mat-label>{{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.TITLE' | translate }}</mat-label>\r\n    <mat-select (openedChange)=\"saveWritingStyleBeforeChange($event)\" (selectionChange)=\"checkRephrasedTextSaves()\" [(value)]=\"selectedWritingStyle\">\r\n      <mat-option *ngFor=\"let style of writingStyles\" [value]=\"style\">\r\n        {{ 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (style | uppercase) | translate }}\r\n      </mat-option>\r\n    </mat-select>\r\n  </mat-form-field>\r\n\r\n  <p class=\"llm-writing-style text-m-semi-bold\">{{\r\n      \"LLM.REPHRASE_MODAL.WRITING_STYLES.SPECIFIC_STYLE\" | translate : \r\n      { style: 'LLM.REPHRASE_MODAL.WRITING_STYLES.' + (selectedWritingStyle | uppercase) | translate } \r\n    }}\r\n    <span\r\n      class=\"material-icons-outlined info-icon\"\r\n      matTooltipClass=\"multiline-tooltip\"\r\n      matTooltipPosition=\"above\" \r\n      [matTooltip]=\"'LLM.REPHRASE_MODAL.WRITING_STYLES.TOOLTIP_' + (selectedWritingStyle | uppercase) | translate\" \r\n    >\r\n      info\r\n    </span>\r\n  </p>\r\n\r\n  <lib-llm-textarea [text]=\"rephrasedText !== '' ? rephrasedText : initialText\" [disabled]=\"isLoading || !rephraseQuotaLeft\" (textEditEvent)=\"textEditEvent($event)\" (copyEvent)=\"copyEvent()\" (dislikeEvent)=\"dislikeEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-rephrase-actions-wrapper\" mat-dialog-actions>\r\n  <div *ngIf=\"showRemainingQuotaMessage\" [innerHTML]=\"'LLM.REPHRASE_MODAL.LIMIT' | translate: { limit: rephraseQuotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n  <div [class.w-full]=\"!showRemainingQuotaMessage\" class=\"llm-rephrase-actions\">\r\n    <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n      {{ \"LLM.REPHRASE_MODAL.CANCEL\" | translate }}\r\n    </button>\r\n\r\n    <ng-template #closeButton>\r\n      <button mat-button color=\"accent\" [mat-dialog-close]=\"null\">\r\n        {{ \"LLM.REPHRASE_MODAL.CLOSE\" | translate }}\r\n      </button>\r\n    </ng-template>\r\n    \r\n    <button\r\n      mat-flat-button\r\n      color=\"accent\"\r\n      (click)=\"rephraseText()\"\r\n      [disabled]=\"isRephrasingDisabled\"\r\n    >\r\n      {{ \"LLM.REPHRASE_MODAL.REPHRASE\" | translate }}\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
@@ -14,12 +14,13 @@ import * as i6 from "@angular/material/menu";
14
14
  import * as i7 from "@angular/material/tooltip";
15
15
  import * as i8 from "@ngx-translate/core";
16
16
  export class LLMComponent {
17
- get isTextSummarasible() {
17
+ get isTextSummarizable() {
18
18
  return this.text.length > 100;
19
19
  }
20
20
  constructor(dialog, iconService) {
21
21
  this.dialog = dialog;
22
22
  this.iconService = iconService;
23
+ this.rephrasableLanguagesCodeList = ['en'];
23
24
  this.llmActions = Object.values(LLMActions);
24
25
  this.llmAction = LLMActions;
25
26
  this.iconService.registerIcons(icons);
@@ -42,16 +43,20 @@ export class LLMComponent {
42
43
  }
43
44
  }
44
45
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LLMComponent, deps: [{ token: i1.MatDialog }, { token: i2.IconService }], target: i0.ɵɵFactoryTarget.Component }); }
45
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LLMComponent, selector: "lib-llm", inputs: { text: "text", language: "language", llmActions: "llmActions" }, ngImport: i0, template: "<button [matTooltip]=\"'LLM.MENU_TOOLTIP' | translate\" mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon svgIcon=\"llm_menu\"></mat-icon>\r\n</button>\r\n\r\n<mat-menu #menu=\"matMenu\">\r\n <ng-container *ngFor=\"let action of llmActions\">\r\n <button\r\n mat-menu-item\r\n [disabled]=\"action === llmAction.SUMMARY && !isTextSummarasible\"\r\n (click)=\"openLLMModal(action)\"\r\n >\r\n {{ \"LLM.\" + action | translate }}\r\n </button>\r\n </ng-container>\r\n</mat-menu>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i6.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i6.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
46
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LLMComponent, selector: "lib-llm", inputs: { text: "text", language: "language", isMenuDisabled: "isMenuDisabled", rephrasableLanguagesCodeList: "rephrasableLanguagesCodeList", llmActions: "llmActions" }, ngImport: i0, template: "<button [disabled]=\"isMenuDisabled\" [matTooltip]=\"'LLM.MENU_TOOLTIP' | translate\" mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon svgIcon=\"llm_menu\"></mat-icon>\r\n</button>\r\n\r\n<mat-menu #menu=\"matMenu\">\r\n <ng-container *ngFor=\"let action of llmActions\">\r\n <div [matTooltip]=\"((action === llmAction.REPHRASE) && !rephrasableLanguagesCodeList.includes(language)) ? ('LLM.MENU_REPHRASE_DISABLED_TOOLTIP' | translate) : ''\">\r\n <button\r\n mat-menu-item\r\n [disabled]=\"((action === llmAction.SUMMARY) && !isTextSummarizable) || ((action === llmAction.REPHRASE) && !rephrasableLanguagesCodeList.includes(language))\"\r\n (click)=\"openLLMModal(action)\"\r\n >\r\n {{ \"LLM.\" + action | translate }}\r\n </button>\r\n </div>\r\n </ng-container>\r\n</mat-menu>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i6.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i6.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
46
47
  }
47
48
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LLMComponent, decorators: [{
48
49
  type: Component,
49
- args: [{ selector: 'lib-llm', template: "<button [matTooltip]=\"'LLM.MENU_TOOLTIP' | translate\" mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon svgIcon=\"llm_menu\"></mat-icon>\r\n</button>\r\n\r\n<mat-menu #menu=\"matMenu\">\r\n <ng-container *ngFor=\"let action of llmActions\">\r\n <button\r\n mat-menu-item\r\n [disabled]=\"action === llmAction.SUMMARY && !isTextSummarasible\"\r\n (click)=\"openLLMModal(action)\"\r\n >\r\n {{ \"LLM.\" + action | translate }}\r\n </button>\r\n </ng-container>\r\n</mat-menu>\r\n" }]
50
+ args: [{ selector: 'lib-llm', template: "<button [disabled]=\"isMenuDisabled\" [matTooltip]=\"'LLM.MENU_TOOLTIP' | translate\" mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon svgIcon=\"llm_menu\"></mat-icon>\r\n</button>\r\n\r\n<mat-menu #menu=\"matMenu\">\r\n <ng-container *ngFor=\"let action of llmActions\">\r\n <div [matTooltip]=\"((action === llmAction.REPHRASE) && !rephrasableLanguagesCodeList.includes(language)) ? ('LLM.MENU_REPHRASE_DISABLED_TOOLTIP' | translate) : ''\">\r\n <button\r\n mat-menu-item\r\n [disabled]=\"((action === llmAction.SUMMARY) && !isTextSummarizable) || ((action === llmAction.REPHRASE) && !rephrasableLanguagesCodeList.includes(language))\"\r\n (click)=\"openLLMModal(action)\"\r\n >\r\n {{ \"LLM.\" + action | translate }}\r\n </button>\r\n </div>\r\n </ng-container>\r\n</mat-menu>\r\n" }]
50
51
  }], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i2.IconService }]; }, propDecorators: { text: [{
51
52
  type: Input
52
53
  }], language: [{
53
54
  type: Input
55
+ }], isMenuDisabled: [{
56
+ type: Input
57
+ }], rephrasableLanguagesCodeList: [{
58
+ type: Input
54
59
  }], llmActions: [{
55
60
  type: Input
56
61
  }] } });
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV2RCxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxrRUFBa0UsQ0FBQztBQUNoSCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUM5RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFHOUMsT0FBTyxLQUFLLEtBQUssTUFBTSxTQUFTLENBQUM7Ozs7Ozs7Ozs7QUFPakMsTUFBTSxPQUFPLFlBQVk7SUFPdkIsSUFBSSxrQkFBa0I7UUFDcEIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxHQUFHLENBQUM7SUFDaEMsQ0FBQztJQUVELFlBQW1CLE1BQWlCLEVBQW1CLFdBQXdCO1FBQTVELFdBQU0sR0FBTixNQUFNLENBQVc7UUFBbUIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFSdEUsZUFBVSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFaEQsY0FBUyxHQUFHLFVBQVUsQ0FBQztRQU9yQixJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsWUFBWSxDQUFDLE1BQWtCO1FBQzdCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUNyRCxRQUFRLEVBQUUsZ0JBQWdCLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsT0FBTztZQUMzRCxJQUFJLEVBQUU7Z0JBQ0osSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO2dCQUNmLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTthQUN4QjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFTyx1QkFBdUIsQ0FBQyxNQUFrQjtRQUNoRCxRQUFRLE1BQU0sRUFBRTtZQUNkLEtBQUssVUFBVSxDQUFDLFFBQVE7Z0JBQ3RCLE9BQU8sNEJBQTRCLENBQUM7WUFDdEMsS0FBSyxVQUFVLENBQUMsT0FBTztnQkFDckIsT0FBTyxzQkFBc0IsQ0FBQztTQUNqQztJQUNILENBQUM7K0dBaENVLFlBQVk7bUdBQVosWUFBWSx5SENmekIseWdCQWVBOzs0RkRBYSxZQUFZO2tCQUx4QixTQUFTOytCQUNFLFNBQVM7MEhBS1YsSUFBSTtzQkFBWixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTExNQWN0aW9ucyB9IGZyb20gJy4vbW9kZWxzL2xsbS1hY3Rpb25zLmVudW0nO1xyXG5pbXBvcnQgeyBNYXREaWFsb2cgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyBSZXBocmFzZVRyYW5zbGF0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3JlcGhyYXNlLXRyYW5zbGF0aW9uL3JlcGhyYXNlLXRyYW5zbGF0aW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENyZWF0ZVN1bW1hcnlDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvY3JlYXRlLXN1bW1hcnkvY3JlYXRlLXN1bW1hcnkuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUmVzb2x1dGlvbkhlbHBlciB9IGZyb20gJy4uL2hlbHBlcnMnO1xyXG5pbXBvcnQgeyBJY29uU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzJztcclxuaW1wb3J0IHsgQ29tcG9uZW50VHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xyXG5pbXBvcnQgKiBhcyBpY29ucyBmcm9tICcuL2ljb25zJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLWxsbScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2xsbS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbGxtLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMTE1Db21wb25lbnQge1xyXG4gIEBJbnB1dCgpIHRleHQhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgbGFuZ3VhZ2UhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgbGxtQWN0aW9ucyA9IE9iamVjdC52YWx1ZXMoTExNQWN0aW9ucyk7XHJcblxyXG4gIGxsbUFjdGlvbiA9IExMTUFjdGlvbnM7XHJcblxyXG4gIGdldCBpc1RleHRTdW1tYXJhc2libGUoKSB7XHJcbiAgICByZXR1cm4gdGhpcy50ZXh0Lmxlbmd0aCA+IDEwMDtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBkaWFsb2c6IE1hdERpYWxvZywgcHJpdmF0ZSByZWFkb25seSBpY29uU2VydmljZTogSWNvblNlcnZpY2UpIHtcclxuICAgIHRoaXMuaWNvblNlcnZpY2UucmVnaXN0ZXJJY29ucyhpY29ucyk7XHJcbiAgfVxyXG5cclxuICBvcGVuTExNTW9kYWwoYWN0aW9uOiBMTE1BY3Rpb25zKTogdm9pZCB7XHJcbiAgICB0aGlzLmRpYWxvZy5vcGVuKHRoaXMuZ2V0Q29tcG9uZW50QnlMTE1BY3Rpb24oYWN0aW9uKSwge1xyXG4gICAgICBtaW5XaWR0aDogUmVzb2x1dGlvbkhlbHBlci5pc01vYmlsZVJlcygpID8gJzEwMCUnIDogJzgwMHB4JyxcclxuICAgICAgZGF0YToge1xyXG4gICAgICAgIHRleHQ6IHRoaXMudGV4dCxcclxuICAgICAgICBsYW5ndWFnZTogdGhpcy5sYW5ndWFnZVxyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgZ2V0Q29tcG9uZW50QnlMTE1BY3Rpb24oYWN0aW9uOiBMTE1BY3Rpb25zKTogQ29tcG9uZW50VHlwZTxSZXBocmFzZVRyYW5zbGF0aW9uQ29tcG9uZW50IHwgQ3JlYXRlU3VtbWFyeUNvbXBvbmVudD4ge1xyXG4gICAgc3dpdGNoIChhY3Rpb24pIHtcclxuICAgICAgY2FzZSBMTE1BY3Rpb25zLlJFUEhSQVNFOlxyXG4gICAgICAgIHJldHVybiBSZXBocmFzZVRyYW5zbGF0aW9uQ29tcG9uZW50O1xyXG4gICAgICBjYXNlIExMTUFjdGlvbnMuU1VNTUFSWTpcclxuICAgICAgICByZXR1cm4gQ3JlYXRlU3VtbWFyeUNvbXBvbmVudDtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPGJ1dHRvbiBbbWF0VG9vbHRpcF09XCInTExNLk1FTlVfVE9PTFRJUCcgfCB0cmFuc2xhdGVcIiBtYXQtaWNvbi1idXR0b24gW21hdE1lbnVUcmlnZ2VyRm9yXT1cIm1lbnVcIj5cclxuICA8bWF0LWljb24gc3ZnSWNvbj1cImxsbV9tZW51XCI+PC9tYXQtaWNvbj5cclxuPC9idXR0b24+XHJcblxyXG48bWF0LW1lbnUgI21lbnU9XCJtYXRNZW51XCI+XHJcbiAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgYWN0aW9uIG9mIGxsbUFjdGlvbnNcIj5cclxuICAgIDxidXR0b25cclxuICAgICAgbWF0LW1lbnUtaXRlbVxyXG4gICAgICBbZGlzYWJsZWRdPVwiYWN0aW9uID09PSBsbG1BY3Rpb24uU1VNTUFSWSAmJiAhaXNUZXh0U3VtbWFyYXNpYmxlXCJcclxuICAgICAgKGNsaWNrKT1cIm9wZW5MTE1Nb2RhbChhY3Rpb24pXCJcclxuICAgID5cclxuICAgICAge3sgXCJMTE0uXCIgKyBhY3Rpb24gfCB0cmFuc2xhdGUgfX1cclxuICA8L2J1dHRvbj5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuPC9tYXQtbWVudT5cclxuIl19
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV2RCxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxrRUFBa0UsQ0FBQztBQUNoSCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUM5RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFHOUMsT0FBTyxLQUFLLEtBQUssTUFBTSxTQUFTLENBQUM7Ozs7Ozs7Ozs7QUFPakMsTUFBTSxPQUFPLFlBQVk7SUFTdkIsSUFBSSxrQkFBa0I7UUFDcEIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxHQUFHLENBQUM7SUFDaEMsQ0FBQztJQUVELFlBQW1CLE1BQWlCLEVBQW1CLFdBQXdCO1FBQTVELFdBQU0sR0FBTixNQUFNLENBQVc7UUFBbUIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFUdEUsaUNBQTRCLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN0QyxlQUFVLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUV2QyxjQUFTLEdBQUcsVUFBVSxDQUFDO1FBTzlCLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRCxZQUFZLENBQUMsTUFBa0I7UUFDN0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLHVCQUF1QixDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQ3JELFFBQVEsRUFBRSxnQkFBZ0IsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxPQUFPO1lBQzNELElBQUksRUFBRTtnQkFDSixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7Z0JBQ2YsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO2FBQ3hCO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVPLHVCQUF1QixDQUFDLE1BQWtCO1FBQ2hELFFBQVEsTUFBTSxFQUFFO1lBQ2QsS0FBSyxVQUFVLENBQUMsUUFBUTtnQkFDdEIsT0FBTyw0QkFBNEIsQ0FBQztZQUN0QyxLQUFLLFVBQVUsQ0FBQyxPQUFPO2dCQUNyQixPQUFPLHNCQUFzQixDQUFDO1NBQ2pDO0lBQ0gsQ0FBQzsrR0FsQ1UsWUFBWTttR0FBWixZQUFZLHlOQ2Z6QixnMUJBaUJBOzs0RkRGYSxZQUFZO2tCQUx4QixTQUFTOytCQUNFLFNBQVM7MEhBS1YsSUFBSTtzQkFBWixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSztnQkFDRyw0QkFBNEI7c0JBQXBDLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTExNQWN0aW9ucyB9IGZyb20gJy4vbW9kZWxzL2xsbS1hY3Rpb25zLmVudW0nO1xyXG5pbXBvcnQgeyBNYXREaWFsb2cgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyBSZXBocmFzZVRyYW5zbGF0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3JlcGhyYXNlLXRyYW5zbGF0aW9uL3JlcGhyYXNlLXRyYW5zbGF0aW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENyZWF0ZVN1bW1hcnlDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvY3JlYXRlLXN1bW1hcnkvY3JlYXRlLXN1bW1hcnkuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUmVzb2x1dGlvbkhlbHBlciB9IGZyb20gJy4uL2hlbHBlcnMnO1xyXG5pbXBvcnQgeyBJY29uU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzJztcclxuaW1wb3J0IHsgQ29tcG9uZW50VHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xyXG5pbXBvcnQgKiBhcyBpY29ucyBmcm9tICcuL2ljb25zJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLWxsbScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2xsbS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbGxtLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMTE1Db21wb25lbnQge1xyXG4gIEBJbnB1dCgpIHRleHQhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgbGFuZ3VhZ2UhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgaXNNZW51RGlzYWJsZWQhOiBib29sZWFuO1xyXG4gIEBJbnB1dCgpIHJlcGhyYXNhYmxlTGFuZ3VhZ2VzQ29kZUxpc3QgPSBbJ2VuJ107XHJcbiAgQElucHV0KCkgbGxtQWN0aW9ucyA9IE9iamVjdC52YWx1ZXMoTExNQWN0aW9ucyk7XHJcblxyXG4gIHJlYWRvbmx5IGxsbUFjdGlvbiA9IExMTUFjdGlvbnM7XHJcblxyXG4gIGdldCBpc1RleHRTdW1tYXJpemFibGUoKSB7XHJcbiAgICByZXR1cm4gdGhpcy50ZXh0Lmxlbmd0aCA+IDEwMDtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBkaWFsb2c6IE1hdERpYWxvZywgcHJpdmF0ZSByZWFkb25seSBpY29uU2VydmljZTogSWNvblNlcnZpY2UpIHtcclxuICAgIHRoaXMuaWNvblNlcnZpY2UucmVnaXN0ZXJJY29ucyhpY29ucyk7XHJcbiAgfVxyXG5cclxuICBvcGVuTExNTW9kYWwoYWN0aW9uOiBMTE1BY3Rpb25zKTogdm9pZCB7XHJcbiAgICB0aGlzLmRpYWxvZy5vcGVuKHRoaXMuZ2V0Q29tcG9uZW50QnlMTE1BY3Rpb24oYWN0aW9uKSwge1xyXG4gICAgICBtaW5XaWR0aDogUmVzb2x1dGlvbkhlbHBlci5pc01vYmlsZVJlcygpID8gJzEwMCUnIDogJzgwMHB4JyxcclxuICAgICAgZGF0YToge1xyXG4gICAgICAgIHRleHQ6IHRoaXMudGV4dCxcclxuICAgICAgICBsYW5ndWFnZTogdGhpcy5sYW5ndWFnZVxyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgZ2V0Q29tcG9uZW50QnlMTE1BY3Rpb24oYWN0aW9uOiBMTE1BY3Rpb25zKTogQ29tcG9uZW50VHlwZTxSZXBocmFzZVRyYW5zbGF0aW9uQ29tcG9uZW50IHwgQ3JlYXRlU3VtbWFyeUNvbXBvbmVudD4ge1xyXG4gICAgc3dpdGNoIChhY3Rpb24pIHtcclxuICAgICAgY2FzZSBMTE1BY3Rpb25zLlJFUEhSQVNFOlxyXG4gICAgICAgIHJldHVybiBSZXBocmFzZVRyYW5zbGF0aW9uQ29tcG9uZW50O1xyXG4gICAgICBjYXNlIExMTUFjdGlvbnMuU1VNTUFSWTpcclxuICAgICAgICByZXR1cm4gQ3JlYXRlU3VtbWFyeUNvbXBvbmVudDtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPGJ1dHRvbiBbZGlzYWJsZWRdPVwiaXNNZW51RGlzYWJsZWRcIiBbbWF0VG9vbHRpcF09XCInTExNLk1FTlVfVE9PTFRJUCcgfCB0cmFuc2xhdGVcIiBtYXQtaWNvbi1idXR0b24gW21hdE1lbnVUcmlnZ2VyRm9yXT1cIm1lbnVcIj5cclxuICA8bWF0LWljb24gc3ZnSWNvbj1cImxsbV9tZW51XCI+PC9tYXQtaWNvbj5cclxuPC9idXR0b24+XHJcblxyXG48bWF0LW1lbnUgI21lbnU9XCJtYXRNZW51XCI+XHJcbiAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgYWN0aW9uIG9mIGxsbUFjdGlvbnNcIj5cclxuICAgIDxkaXYgW21hdFRvb2x0aXBdPVwiKChhY3Rpb24gPT09IGxsbUFjdGlvbi5SRVBIUkFTRSkgJiYgIXJlcGhyYXNhYmxlTGFuZ3VhZ2VzQ29kZUxpc3QuaW5jbHVkZXMobGFuZ3VhZ2UpKSA/ICgnTExNLk1FTlVfUkVQSFJBU0VfRElTQUJMRURfVE9PTFRJUCcgfCB0cmFuc2xhdGUpIDogJydcIj5cclxuICAgICAgPGJ1dHRvblxyXG4gICAgICAgIG1hdC1tZW51LWl0ZW1cclxuICAgICAgICBbZGlzYWJsZWRdPVwiKChhY3Rpb24gPT09IGxsbUFjdGlvbi5TVU1NQVJZKSAmJiAhaXNUZXh0U3VtbWFyaXphYmxlKSB8fCAoKGFjdGlvbiA9PT0gbGxtQWN0aW9uLlJFUEhSQVNFKSAmJiAhcmVwaHJhc2FibGVMYW5ndWFnZXNDb2RlTGlzdC5pbmNsdWRlcyhsYW5ndWFnZSkpXCJcclxuICAgICAgICAoY2xpY2spPVwib3BlbkxMTU1vZGFsKGFjdGlvbilcIlxyXG4gICAgICA+XHJcbiAgICAgICAge3sgXCJMTE0uXCIgKyBhY3Rpb24gfCB0cmFuc2xhdGUgfX1cclxuICAgICAgPC9idXR0b24+XHJcbiAgICA8L2Rpdj5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuPC9tYXQtbWVudT5cclxuIl19
@@ -5,10 +5,11 @@ import * as i1 from "./llm.service";
5
5
  export class LLMHelperService {
6
6
  constructor(llmService) {
7
7
  this.llmService = llmService;
8
+ this.LLMQuotaLocalStorageKey = 'LLM_QUOTA';
8
9
  }
9
- setQuotaLocalStorageUsage(quotaLocalStorageKey, decrease) {
10
+ setQuotaLocalStorageUsage(decrease) {
10
11
  const trialRequestCount = 15;
11
- const localStorageObj = localStorage.getItem(quotaLocalStorageKey);
12
+ const localStorageObj = localStorage.getItem(this.LLMQuotaLocalStorageKey);
12
13
  const currentDate = new Date();
13
14
  let trialQuota = {
14
15
  remainingQuota: trialRequestCount,
@@ -28,20 +29,27 @@ export class LLMHelperService {
28
29
  }
29
30
  }
30
31
  trialQuota.lastUsedAt = currentDate;
31
- localStorage.setItem(quotaLocalStorageKey, JSON.stringify(trialQuota));
32
+ localStorage.setItem(this.LLMQuotaLocalStorageKey, JSON.stringify(trialQuota));
32
33
  return trialQuota.remainingQuota;
33
34
  }
34
35
  getReachedQuotaMessage() {
35
36
  return {
36
37
  type: NotificationMessageType.ERROR,
37
38
  body: 'LLM.ERRORS.QUOTA_LIMIT_REACHED',
38
- hideClose: true,
39
39
  hideIcon: true,
40
40
  localizationParams: {
41
41
  subscriptionUrl: this.llmService.llmConfiguration.subscriptionUrl,
42
42
  },
43
43
  };
44
44
  }
45
+ getDefaultErrorMessage() {
46
+ return {
47
+ type: NotificationMessageType.ERROR,
48
+ body: 'LLM.ERRORS.DEFAULT',
49
+ hideIcon: true,
50
+ localizationParams: { supportEmail: this.llmService.llmConfiguration.supportEmail }
51
+ };
52
+ }
45
53
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LLMHelperService, deps: [{ token: i1.LLMService }], target: i0.ɵɵFactoryTarget.Injectable }); }
46
54
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LLMHelperService, providedIn: 'root' }); }
47
55
  }
@@ -51,4 +59,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
51
59
  providedIn: 'root'
52
60
  }]
53
61
  }], ctorParameters: function () { return [{ type: i1.LLMService }]; } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLWhlbHBlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL2xsbS9zZXJ2aWNlcy9sbG0taGVscGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQXVCLHVCQUF1QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQU0xRixNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLFlBQThCLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7SUFBRyxDQUFDO0lBRXhELHlCQUF5QixDQUFDLG9CQUE0QixFQUFFLFFBQWtCO1FBQ3hFLE1BQU0saUJBQWlCLEdBQUcsRUFBRSxDQUFDO1FBQzdCLE1BQU0sZUFBZSxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUNuRSxNQUFNLFdBQVcsR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO1FBQy9CLElBQUksVUFBVSxHQUFHO1lBQ2YsY0FBYyxFQUFFLGlCQUFpQjtZQUNqQyxVQUFVLEVBQUUsV0FBVztTQUN4QixDQUFDO1FBRUYsSUFBSSxlQUFlLEVBQUU7WUFDbkIsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQztZQUM5QyxVQUFVLEdBQUcsU0FBUyxDQUFDO1lBRXZCLE1BQU0sWUFBWSxHQUFHLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUVyRCxvRUFBb0U7WUFDcEUsSUFBSSxZQUFZLENBQUMsT0FBTyxFQUFFLEtBQUssV0FBVyxDQUFDLE9BQU8sRUFBRSxJQUFJLFlBQVksQ0FBQyxRQUFRLEVBQUUsS0FBSyxXQUFXLENBQUMsUUFBUSxFQUFFLElBQUksWUFBWSxDQUFDLFdBQVcsRUFBRSxLQUFLLFdBQVcsQ0FBQyxXQUFXLEVBQUUsRUFBRTtnQkFDdEssaUNBQWlDO2dCQUNqQyxVQUFVLENBQUMsY0FBYyxHQUFHLGlCQUFpQixDQUFDO2FBQy9DO1lBRUQsSUFBSSxRQUFRLEVBQUU7Z0JBQ1osVUFBVSxDQUFDLGNBQWMsSUFBSSxDQUFDLENBQUM7YUFDaEM7U0FDRjtRQUVELFVBQVUsQ0FBQyxVQUFVLEdBQUcsV0FBVyxDQUFDO1FBRXBDLFlBQVksQ0FBQyxPQUFPLENBQUMsb0JBQW9CLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBRXZFLE9BQU8sVUFBVSxDQUFDLGNBQWMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsc0JBQXNCO1FBQ3BCLE9BQU87WUFDTCxJQUFJLEVBQUUsdUJBQXVCLENBQUMsS0FBSztZQUNuQyxJQUFJLEVBQUUsZ0NBQWdDO1lBQ3RDLFNBQVMsRUFBRSxJQUFJO1lBQ2YsUUFBUSxFQUFFLElBQUk7WUFDZCxrQkFBa0IsRUFBRTtnQkFDbEIsZUFBZSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQUMsZUFBZTthQUNsRTtTQUNGLENBQUM7SUFDSixDQUFDOytHQTlDVSxnQkFBZ0I7bUhBQWhCLGdCQUFnQixjQUZmLE1BQU07OzRGQUVQLGdCQUFnQjtrQkFINUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE5vdGlmaWNhdGlvbk1lc3NhZ2UsIE5vdGlmaWNhdGlvbk1lc3NhZ2VUeXBlIH0gZnJvbSAnLi4vLi4vbm90aWZpY2F0aW9uLW1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBMTE1TZXJ2aWNlIH0gZnJvbSAnLi9sbG0uc2VydmljZSc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMTE1IZWxwZXJTZXJ2aWNlIHtcclxuICBjb25zdHJ1Y3RvciAocHJpdmF0ZSByZWFkb25seSBsbG1TZXJ2aWNlOiBMTE1TZXJ2aWNlKSB7fVxyXG5cclxuICBzZXRRdW90YUxvY2FsU3RvcmFnZVVzYWdlKHF1b3RhTG9jYWxTdG9yYWdlS2V5OiBzdHJpbmcsIGRlY3JlYXNlPzogYm9vbGVhbik6IG51bWJlciB7XHJcbiAgICBjb25zdCB0cmlhbFJlcXVlc3RDb3VudCA9IDE1O1xyXG4gICAgY29uc3QgbG9jYWxTdG9yYWdlT2JqID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0ocXVvdGFMb2NhbFN0b3JhZ2VLZXkpO1xyXG4gICAgY29uc3QgY3VycmVudERhdGUgPSBuZXcgRGF0ZSgpO1xyXG4gICAgbGV0IHRyaWFsUXVvdGEgPSB7XHJcbiAgICAgIHJlbWFpbmluZ1F1b3RhOiB0cmlhbFJlcXVlc3RDb3VudCxcclxuICAgICAgbGFzdFVzZWRBdDogY3VycmVudERhdGVcclxuICAgIH07XHJcbiAgXHJcbiAgICBpZiAobG9jYWxTdG9yYWdlT2JqKSB7XHJcbiAgICAgIGNvbnN0IHBhcnNlZE9iaiA9IEpTT04ucGFyc2UobG9jYWxTdG9yYWdlT2JqKTtcclxuICAgICAgdHJpYWxRdW90YSA9IHBhcnNlZE9iajtcclxuICBcclxuICAgICAgY29uc3QgbGFzdFVzZWREYXRlID0gbmV3IERhdGUodHJpYWxRdW90YS5sYXN0VXNlZEF0KTtcclxuICBcclxuICAgICAgLy8gQ2hlY2tpbmcgaWYgdGhlIGxhc3QgdXNlZCBkYXRlIGlzIGZyb20gYSBkaWZmZXJlbnQgZGF5IHRoYW4gdG9kYXlcclxuICAgICAgaWYgKGxhc3RVc2VkRGF0ZS5nZXREYXRlKCkgIT09IGN1cnJlbnREYXRlLmdldERhdGUoKSB8fCBsYXN0VXNlZERhdGUuZ2V0TW9udGgoKSAhPT0gY3VycmVudERhdGUuZ2V0TW9udGgoKSB8fCBsYXN0VXNlZERhdGUuZ2V0RnVsbFllYXIoKSAhPT0gY3VycmVudERhdGUuZ2V0RnVsbFllYXIoKSkge1xyXG4gICAgICAgIC8vIFJlc2V0aW5nIHF1b3RhIGZvciB0aGUgbmV3IGRheVxyXG4gICAgICAgIHRyaWFsUXVvdGEucmVtYWluaW5nUXVvdGEgPSB0cmlhbFJlcXVlc3RDb3VudDsgIFxyXG4gICAgICB9XHJcbiAgXHJcbiAgICAgIGlmIChkZWNyZWFzZSkge1xyXG4gICAgICAgIHRyaWFsUXVvdGEucmVtYWluaW5nUXVvdGEgLT0gMTtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIFxyXG4gICAgdHJpYWxRdW90YS5sYXN0VXNlZEF0ID0gY3VycmVudERhdGU7XHJcblxyXG4gICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0ocXVvdGFMb2NhbFN0b3JhZ2VLZXksIEpTT04uc3RyaW5naWZ5KHRyaWFsUXVvdGEpKTtcclxuXHJcbiAgICByZXR1cm4gdHJpYWxRdW90YS5yZW1haW5pbmdRdW90YTtcclxuICB9XHJcblxyXG4gIGdldFJlYWNoZWRRdW90YU1lc3NhZ2UoKTogTm90aWZpY2F0aW9uTWVzc2FnZSB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICB0eXBlOiBOb3RpZmljYXRpb25NZXNzYWdlVHlwZS5FUlJPUixcclxuICAgICAgYm9keTogJ0xMTS5FUlJPUlMuUVVPVEFfTElNSVRfUkVBQ0hFRCcsXHJcbiAgICAgIGhpZGVDbG9zZTogdHJ1ZSxcclxuICAgICAgaGlkZUljb246IHRydWUsXHJcbiAgICAgIGxvY2FsaXphdGlvblBhcmFtczoge1xyXG4gICAgICAgIHN1YnNjcmlwdGlvblVybDogdGhpcy5sbG1TZXJ2aWNlLmxsbUNvbmZpZ3VyYXRpb24uc3Vic2NyaXB0aW9uVXJsLFxyXG4gICAgICB9LFxyXG4gICAgfTtcclxuICB9XHJcbn1cclxuIl19
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLWhlbHBlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL2xsbS9zZXJ2aWNlcy9sbG0taGVscGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQXVCLHVCQUF1QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQU0xRixNQUFNLE9BQU8sZ0JBQWdCO0lBRzNCLFlBQThCLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7UUFGbkMsNEJBQXVCLEdBQUcsV0FBVyxDQUFDO0lBRUEsQ0FBQztJQUV4RCx5QkFBeUIsQ0FBQyxRQUFrQjtRQUMxQyxNQUFNLGlCQUFpQixHQUFHLEVBQUUsQ0FBQztRQUM3QixNQUFNLGVBQWUsR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBQzNFLE1BQU0sV0FBVyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUM7UUFDL0IsSUFBSSxVQUFVLEdBQUc7WUFDZixjQUFjLEVBQUUsaUJBQWlCO1lBQ2pDLFVBQVUsRUFBRSxXQUFXO1NBQ3hCLENBQUM7UUFFRixJQUFJLGVBQWUsRUFBRTtZQUNuQixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQzlDLFVBQVUsR0FBRyxTQUFTLENBQUM7WUFFdkIsTUFBTSxZQUFZLEdBQUcsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBRXJELG9FQUFvRTtZQUNwRSxJQUFJLFlBQVksQ0FBQyxPQUFPLEVBQUUsS0FBSyxXQUFXLENBQUMsT0FBTyxFQUFFLElBQUksWUFBWSxDQUFDLFFBQVEsRUFBRSxLQUFLLFdBQVcsQ0FBQyxRQUFRLEVBQUUsSUFBSSxZQUFZLENBQUMsV0FBVyxFQUFFLEtBQUssV0FBVyxDQUFDLFdBQVcsRUFBRSxFQUFFO2dCQUN0SyxpQ0FBaUM7Z0JBQ2pDLFVBQVUsQ0FBQyxjQUFjLEdBQUcsaUJBQWlCLENBQUM7YUFDL0M7WUFFRCxJQUFJLFFBQVEsRUFBRTtnQkFDWixVQUFVLENBQUMsY0FBYyxJQUFJLENBQUMsQ0FBQzthQUNoQztTQUNGO1FBRUQsVUFBVSxDQUFDLFVBQVUsR0FBRyxXQUFXLENBQUM7UUFFcEMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsdUJBQXVCLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBRS9FLE9BQU8sVUFBVSxDQUFDLGNBQWMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsc0JBQXNCO1FBQ3BCLE9BQU87WUFDTCxJQUFJLEVBQUUsdUJBQXVCLENBQUMsS0FBSztZQUNuQyxJQUFJLEVBQUUsZ0NBQWdDO1lBQ3RDLFFBQVEsRUFBRSxJQUFJO1lBQ2Qsa0JBQWtCLEVBQUU7Z0JBQ2xCLGVBQWUsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLGdCQUFnQixDQUFDLGVBQWU7YUFDbEU7U0FDRixDQUFDO0lBQ0osQ0FBQztJQUVELHNCQUFzQjtRQUNwQixPQUFPO1lBQ0wsSUFBSSxFQUFFLHVCQUF1QixDQUFDLEtBQUs7WUFDbkMsSUFBSSxFQUFFLG9CQUFvQjtZQUMxQixRQUFRLEVBQUUsSUFBSTtZQUNkLGtCQUFrQixFQUFFLEVBQUUsWUFBWSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQUMsWUFBWSxFQUFFO1NBQ3BGLENBQUE7SUFDSCxDQUFDOytHQXhEVSxnQkFBZ0I7bUhBQWhCLGdCQUFnQixjQUZmLE1BQU07OzRGQUVQLGdCQUFnQjtrQkFINUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE5vdGlmaWNhdGlvbk1lc3NhZ2UsIE5vdGlmaWNhdGlvbk1lc3NhZ2VUeXBlIH0gZnJvbSAnLi4vLi4vbm90aWZpY2F0aW9uLW1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBMTE1TZXJ2aWNlIH0gZnJvbSAnLi9sbG0uc2VydmljZSc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMTE1IZWxwZXJTZXJ2aWNlIHtcclxuICBwcml2YXRlIHJlYWRvbmx5IExMTVF1b3RhTG9jYWxTdG9yYWdlS2V5ID0gJ0xMTV9RVU9UQSc7XHJcblxyXG4gIGNvbnN0cnVjdG9yIChwcml2YXRlIHJlYWRvbmx5IGxsbVNlcnZpY2U6IExMTVNlcnZpY2UpIHt9XHJcblxyXG4gIHNldFF1b3RhTG9jYWxTdG9yYWdlVXNhZ2UoZGVjcmVhc2U/OiBib29sZWFuKTogbnVtYmVyIHtcclxuICAgIGNvbnN0IHRyaWFsUmVxdWVzdENvdW50ID0gMTU7XHJcbiAgICBjb25zdCBsb2NhbFN0b3JhZ2VPYmogPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLkxMTVF1b3RhTG9jYWxTdG9yYWdlS2V5KTtcclxuICAgIGNvbnN0IGN1cnJlbnREYXRlID0gbmV3IERhdGUoKTtcclxuICAgIGxldCB0cmlhbFF1b3RhID0ge1xyXG4gICAgICByZW1haW5pbmdRdW90YTogdHJpYWxSZXF1ZXN0Q291bnQsXHJcbiAgICAgIGxhc3RVc2VkQXQ6IGN1cnJlbnREYXRlXHJcbiAgICB9O1xyXG4gIFxyXG4gICAgaWYgKGxvY2FsU3RvcmFnZU9iaikge1xyXG4gICAgICBjb25zdCBwYXJzZWRPYmogPSBKU09OLnBhcnNlKGxvY2FsU3RvcmFnZU9iaik7XHJcbiAgICAgIHRyaWFsUXVvdGEgPSBwYXJzZWRPYmo7XHJcbiAgXHJcbiAgICAgIGNvbnN0IGxhc3RVc2VkRGF0ZSA9IG5ldyBEYXRlKHRyaWFsUXVvdGEubGFzdFVzZWRBdCk7XHJcbiAgXHJcbiAgICAgIC8vIENoZWNraW5nIGlmIHRoZSBsYXN0IHVzZWQgZGF0ZSBpcyBmcm9tIGEgZGlmZmVyZW50IGRheSB0aGFuIHRvZGF5XHJcbiAgICAgIGlmIChsYXN0VXNlZERhdGUuZ2V0RGF0ZSgpICE9PSBjdXJyZW50RGF0ZS5nZXREYXRlKCkgfHwgbGFzdFVzZWREYXRlLmdldE1vbnRoKCkgIT09IGN1cnJlbnREYXRlLmdldE1vbnRoKCkgfHwgbGFzdFVzZWREYXRlLmdldEZ1bGxZZWFyKCkgIT09IGN1cnJlbnREYXRlLmdldEZ1bGxZZWFyKCkpIHtcclxuICAgICAgICAvLyBSZXNldGluZyBxdW90YSBmb3IgdGhlIG5ldyBkYXlcclxuICAgICAgICB0cmlhbFF1b3RhLnJlbWFpbmluZ1F1b3RhID0gdHJpYWxSZXF1ZXN0Q291bnQ7ICBcclxuICAgICAgfVxyXG4gIFxyXG4gICAgICBpZiAoZGVjcmVhc2UpIHtcclxuICAgICAgICB0cmlhbFF1b3RhLnJlbWFpbmluZ1F1b3RhIC09IDE7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICBcclxuICAgIHRyaWFsUXVvdGEubGFzdFVzZWRBdCA9IGN1cnJlbnREYXRlO1xyXG5cclxuICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKHRoaXMuTExNUXVvdGFMb2NhbFN0b3JhZ2VLZXksIEpTT04uc3RyaW5naWZ5KHRyaWFsUXVvdGEpKTtcclxuXHJcbiAgICByZXR1cm4gdHJpYWxRdW90YS5yZW1haW5pbmdRdW90YTtcclxuICB9XHJcblxyXG4gIGdldFJlYWNoZWRRdW90YU1lc3NhZ2UoKTogTm90aWZpY2F0aW9uTWVzc2FnZSB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICB0eXBlOiBOb3RpZmljYXRpb25NZXNzYWdlVHlwZS5FUlJPUixcclxuICAgICAgYm9keTogJ0xMTS5FUlJPUlMuUVVPVEFfTElNSVRfUkVBQ0hFRCcsXHJcbiAgICAgIGhpZGVJY29uOiB0cnVlLFxyXG4gICAgICBsb2NhbGl6YXRpb25QYXJhbXM6IHtcclxuICAgICAgICBzdWJzY3JpcHRpb25Vcmw6IHRoaXMubGxtU2VydmljZS5sbG1Db25maWd1cmF0aW9uLnN1YnNjcmlwdGlvblVybCxcclxuICAgICAgfSxcclxuICAgIH07XHJcbiAgfVxyXG5cclxuICBnZXREZWZhdWx0RXJyb3JNZXNzYWdlKCk6IE5vdGlmaWNhdGlvbk1lc3NhZ2Uge1xyXG4gICAgcmV0dXJuIHsgXHJcbiAgICAgIHR5cGU6IE5vdGlmaWNhdGlvbk1lc3NhZ2VUeXBlLkVSUk9SLCBcclxuICAgICAgYm9keTogJ0xMTS5FUlJPUlMuREVGQVVMVCcsXHJcbiAgICAgIGhpZGVJY29uOiB0cnVlLFxyXG4gICAgICBsb2NhbGl6YXRpb25QYXJhbXM6IHsgc3VwcG9ydEVtYWlsOiB0aGlzLmxsbVNlcnZpY2UubGxtQ29uZmlndXJhdGlvbi5zdXBwb3J0RW1haWwgfVxyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=