@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.
- package/esm2022/lib/llm/components/create-summary/create-summary.component.mjs +30 -18
- package/esm2022/lib/llm/components/rephrase-translation/rephrase-translation.component.mjs +52 -17
- package/esm2022/lib/llm/llm.component.mjs +9 -4
- package/esm2022/lib/llm/services/llm-helper.service.mjs +13 -5
- package/esm2022/lib/llm/shared/llm-textarea/llm-textarea.component.mjs +11 -25
- package/fesm2022/tilde-nlp-ngx-common.mjs +169 -119
- package/fesm2022/tilde-nlp-ngx-common.mjs.map +1 -1
- package/lib/llm/components/create-summary/create-summary.component.d.ts +10 -5
- package/lib/llm/components/rephrase-translation/rephrase-translation.component.d.ts +13 -5
- package/lib/llm/llm.component.d.ts +5 -3
- package/lib/llm/services/llm-helper.service.d.ts +3 -1
- package/lib/llm/shared/llm-textarea/llm-textarea.component.d.ts +1 -7
- package/package.json +1 -1
|
@@ -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.
|
|
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.
|
|
35
|
+
this.missingQuotaMessageClosed = false;
|
|
28
36
|
}
|
|
29
37
|
ngOnInit() {
|
|
30
|
-
this.
|
|
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.
|
|
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.
|
|
45
|
-
this.
|
|
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.
|
|
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
|
-
|
|
63
|
-
|
|
64
|
-
|
|
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.
|
|
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=\"
|
|
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=\"
|
|
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":"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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  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.
|
|
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.
|
|
43
|
+
this.missingQuotaMessageClosed = false;
|
|
35
44
|
}
|
|
36
45
|
ngOnInit() {
|
|
37
|
-
this.
|
|
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.
|
|
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.
|
|
50
|
-
this.
|
|
79
|
+
this.rephrasedText = response;
|
|
80
|
+
this.manuallyEditedText = '';
|
|
81
|
+
this.showDefaultErrorMessage = false;
|
|
51
82
|
this.refreshQuota(true);
|
|
52
83
|
},
|
|
53
84
|
error: () => {
|
|
54
|
-
this.
|
|
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
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
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.
|
|
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=\"
|
|
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=\"
|
|
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":"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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  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
|
|
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
|
|
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
|
|
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,
|
|
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(
|
|
10
|
+
setQuotaLocalStorageUsage(decrease) {
|
|
10
11
|
const trialRequestCount = 15;
|
|
11
|
-
const localStorageObj = localStorage.getItem(
|
|
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(
|
|
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,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLWhlbHBlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL2xsbS9zZXJ2aWNlcy9sbG0taGVscGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQXVCLHVCQUF1QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQU0xRixNQUFNLE9BQU8sZ0JBQWdCO0lBRzNCLFlBQThCLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7UUFGbkMsNEJBQXVCLEdBQUcsV0FBVyxDQUFDO0lBRUEsQ0FBQztJQUV4RCx5QkFBeUIsQ0FBQyxRQUFrQjtRQUMxQyxNQUFNLGlCQUFpQixHQUFHLEVBQUUsQ0FBQztRQUM3QixNQUFNLGVBQWUsR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBQzNFLE1BQU0sV0FBVyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUM7UUFDL0IsSUFBSSxVQUFVLEdBQUc7WUFDZixjQUFjLEVBQUUsaUJBQWlCO1lBQ2pDLFVBQVUsRUFBRSxXQUFXO1NBQ3hCLENBQUM7UUFFRixJQUFJLGVBQWUsRUFBRTtZQUNuQixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQzlDLFVBQVUsR0FBRyxTQUFTLENBQUM7WUFFdkIsTUFBTSxZQUFZLEdBQUcsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBRXJELG9FQUFvRTtZQUNwRSxJQUFJLFlBQVksQ0FBQyxPQUFPLEVBQUUsS0FBSyxXQUFXLENBQUMsT0FBTyxFQUFFLElBQUksWUFBWSxDQUFDLFFBQVEsRUFBRSxLQUFLLFdBQVcsQ0FBQyxRQUFRLEVBQUUsSUFBSSxZQUFZLENBQUMsV0FBVyxFQUFFLEtBQUssV0FBVyxDQUFDLFdBQVcsRUFBRSxFQUFFO2dCQUN0SyxpQ0FBaUM7Z0JBQ2pDLFVBQVUsQ0FBQyxjQUFjLEdBQUcsaUJBQWlCLENBQUM7YUFDL0M7WUFFRCxJQUFJLFFBQVEsRUFBRTtnQkFDWixVQUFVLENBQUMsY0FBYyxJQUFJLENBQUMsQ0FBQzthQUNoQztTQUNGO1FBRUQsVUFBVSxDQUFDLFVBQVUsR0FBRyxXQUFXLENBQUM7UUFFcEMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsdUJBQXVCLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBRS9FLE9BQU8sVUFBVSxDQUFDLGNBQWMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsc0JBQXNCO1FBQ3BCLE9BQU87WUFDTCxJQUFJLEVBQUUsdUJBQXVCLENBQUMsS0FBSztZQUNuQyxJQUFJLEVBQUUsZ0NBQWdDO1lBQ3RDLFFBQVEsRUFBRSxJQUFJO1lBQ2Qsa0JBQWtCLEVBQUU7Z0JBQ2xCLGVBQWUsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLGdCQUFnQixDQUFDLGVBQWU7YUFDbEU7U0FDRixDQUFDO0lBQ0osQ0FBQztJQUVELHNCQUFzQjtRQUNwQixPQUFPO1lBQ0wsSUFBSSxFQUFFLHVCQUF1QixDQUFDLEtBQUs7WUFDbkMsSUFBSSxFQUFFLG9CQUFvQjtZQUMxQixRQUFRLEVBQUUsSUFBSTtZQUNkLGtCQUFrQixFQUFFLEVBQUUsWUFBWSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQUMsWUFBWSxFQUFFO1NBQ3BGLENBQUE7SUFDSCxDQUFDOytHQXhEVSxnQkFBZ0I7bUhBQWhCLGdCQUFnQixjQUZmLE1BQU07OzRGQUVQLGdCQUFnQjtrQkFINUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE5vdGlmaWNhdGlvbk1lc3NhZ2UsIE5vdGlmaWNhdGlvbk1lc3NhZ2VUeXBlIH0gZnJvbSAnLi4vLi4vbm90aWZpY2F0aW9uLW1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBMTE1TZXJ2aWNlIH0gZnJvbSAnLi9sbG0uc2VydmljZSc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMTE1IZWxwZXJTZXJ2aWNlIHtcclxuICBwcml2YXRlIHJlYWRvbmx5IExMTVF1b3RhTG9jYWxTdG9yYWdlS2V5ID0gJ0xMTV9RVU9UQSc7XHJcblxyXG4gIGNvbnN0cnVjdG9yIChwcml2YXRlIHJlYWRvbmx5IGxsbVNlcnZpY2U6IExMTVNlcnZpY2UpIHt9XHJcblxyXG4gIHNldFF1b3RhTG9jYWxTdG9yYWdlVXNhZ2UoZGVjcmVhc2U/OiBib29sZWFuKTogbnVtYmVyIHtcclxuICAgIGNvbnN0IHRyaWFsUmVxdWVzdENvdW50ID0gMTU7XHJcbiAgICBjb25zdCBsb2NhbFN0b3JhZ2VPYmogPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLkxMTVF1b3RhTG9jYWxTdG9yYWdlS2V5KTtcclxuICAgIGNvbnN0IGN1cnJlbnREYXRlID0gbmV3IERhdGUoKTtcclxuICAgIGxldCB0cmlhbFF1b3RhID0ge1xyXG4gICAgICByZW1haW5pbmdRdW90YTogdHJpYWxSZXF1ZXN0Q291bnQsXHJcbiAgICAgIGxhc3RVc2VkQXQ6IGN1cnJlbnREYXRlXHJcbiAgICB9O1xyXG4gIFxyXG4gICAgaWYgKGxvY2FsU3RvcmFnZU9iaikge1xyXG4gICAgICBjb25zdCBwYXJzZWRPYmogPSBKU09OLnBhcnNlKGxvY2FsU3RvcmFnZU9iaik7XHJcbiAgICAgIHRyaWFsUXVvdGEgPSBwYXJzZWRPYmo7XHJcbiAgXHJcbiAgICAgIGNvbnN0IGxhc3RVc2VkRGF0ZSA9IG5ldyBEYXRlKHRyaWFsUXVvdGEubGFzdFVzZWRBdCk7XHJcbiAgXHJcbiAgICAgIC8vIENoZWNraW5nIGlmIHRoZSBsYXN0IHVzZWQgZGF0ZSBpcyBmcm9tIGEgZGlmZmVyZW50IGRheSB0aGFuIHRvZGF5XHJcbiAgICAgIGlmIChsYXN0VXNlZERhdGUuZ2V0RGF0ZSgpICE9PSBjdXJyZW50RGF0ZS5nZXREYXRlKCkgfHwgbGFzdFVzZWREYXRlLmdldE1vbnRoKCkgIT09IGN1cnJlbnREYXRlLmdldE1vbnRoKCkgfHwgbGFzdFVzZWREYXRlLmdldEZ1bGxZZWFyKCkgIT09IGN1cnJlbnREYXRlLmdldEZ1bGxZZWFyKCkpIHtcclxuICAgICAgICAvLyBSZXNldGluZyBxdW90YSBmb3IgdGhlIG5ldyBkYXlcclxuICAgICAgICB0cmlhbFF1b3RhLnJlbWFpbmluZ1F1b3RhID0gdHJpYWxSZXF1ZXN0Q291bnQ7ICBcclxuICAgICAgfVxyXG4gIFxyXG4gICAgICBpZiAoZGVjcmVhc2UpIHtcclxuICAgICAgICB0cmlhbFF1b3RhLnJlbWFpbmluZ1F1b3RhIC09IDE7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICBcclxuICAgIHRyaWFsUXVvdGEubGFzdFVzZWRBdCA9IGN1cnJlbnREYXRlO1xyXG5cclxuICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKHRoaXMuTExNUXVvdGFMb2NhbFN0b3JhZ2VLZXksIEpTT04uc3RyaW5naWZ5KHRyaWFsUXVvdGEpKTtcclxuXHJcbiAgICByZXR1cm4gdHJpYWxRdW90YS5yZW1haW5pbmdRdW90YTtcclxuICB9XHJcblxyXG4gIGdldFJlYWNoZWRRdW90YU1lc3NhZ2UoKTogTm90aWZpY2F0aW9uTWVzc2FnZSB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICB0eXBlOiBOb3RpZmljYXRpb25NZXNzYWdlVHlwZS5FUlJPUixcclxuICAgICAgYm9keTogJ0xMTS5FUlJPUlMuUVVPVEFfTElNSVRfUkVBQ0hFRCcsXHJcbiAgICAgIGhpZGVJY29uOiB0cnVlLFxyXG4gICAgICBsb2NhbGl6YXRpb25QYXJhbXM6IHtcclxuICAgICAgICBzdWJzY3JpcHRpb25Vcmw6IHRoaXMubGxtU2VydmljZS5sbG1Db25maWd1cmF0aW9uLnN1YnNjcmlwdGlvblVybCxcclxuICAgICAgfSxcclxuICAgIH07XHJcbiAgfVxyXG5cclxuICBnZXREZWZhdWx0RXJyb3JNZXNzYWdlKCk6IE5vdGlmaWNhdGlvbk1lc3NhZ2Uge1xyXG4gICAgcmV0dXJuIHsgXHJcbiAgICAgIHR5cGU6IE5vdGlmaWNhdGlvbk1lc3NhZ2VUeXBlLkVSUk9SLCBcclxuICAgICAgYm9keTogJ0xMTS5FUlJPUlMuREVGQVVMVCcsXHJcbiAgICAgIGhpZGVJY29uOiB0cnVlLFxyXG4gICAgICBsb2NhbGl6YXRpb25QYXJhbXM6IHsgc3VwcG9ydEVtYWlsOiB0aGlzLmxsbVNlcnZpY2UubGxtQ29uZmlndXJhdGlvbi5zdXBwb3J0RW1haWwgfVxyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
|