@tilde-nlp/ngx-common 4.1.28 → 4.1.29
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 +22 -18
- package/esm2022/lib/llm/components/rephrase/rephrase.component.mjs +138 -0
- package/esm2022/lib/llm/llm.component.mjs +17 -17
- package/esm2022/lib/llm/llm.module.mjs +11 -7
- package/esm2022/lib/llm/models/llm-configuration.model.mjs +1 -1
- package/esm2022/lib/llm/shared/llm-textarea/llm-textarea.component.mjs +17 -11
- package/fesm2022/tilde-nlp-ngx-common.mjs +123 -137
- package/fesm2022/tilde-nlp-ngx-common.mjs.map +1 -1
- package/lib/llm/components/create-summary/create-summary.component.d.ts +4 -5
- package/lib/llm/components/{rephrase-translation/rephrase-translation.component.d.ts → rephrase/rephrase.component.d.ts} +7 -9
- package/lib/llm/llm.component.d.ts +5 -4
- package/lib/llm/llm.module.d.ts +3 -2
- package/lib/llm/models/llm-configuration.model.d.ts +0 -1
- package/lib/llm/shared/llm-textarea/llm-textarea.component.d.ts +3 -0
- package/package.json +1 -1
- package/styles/components/icons.scss +4 -0
- package/styles/variables/colors.variables.scss +1 -0
- package/esm2022/lib/llm/components/rephrase-translation/rephrase-translation.component.mjs +0 -134
- package/esm2022/lib/llm/services/plausible.service.mjs +0 -34
- package/lib/llm/services/plausible.service.d.ts +0 -13
|
@@ -2,15 +2,16 @@ import { Component, Inject } from '@angular/core';
|
|
|
2
2
|
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
3
|
import { finalize } from 'rxjs';
|
|
4
4
|
import { QuotaType } from '../../../services';
|
|
5
|
+
import { PlausibleHelper } from '../../../plausible';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "../../services/llm.service";
|
|
7
8
|
import * as i2 from "../../services/llm-helper.service";
|
|
8
9
|
import * as i3 from "../../../services";
|
|
9
|
-
import * as i4 from "
|
|
10
|
-
import * as i5 from "@angular/
|
|
11
|
-
import * as i6 from "@angular/material/
|
|
12
|
-
import * as i7 from "
|
|
13
|
-
import * as i8 from "
|
|
10
|
+
import * as i4 from "@angular/common";
|
|
11
|
+
import * as i5 from "@angular/material/button";
|
|
12
|
+
import * as i6 from "@angular/material/dialog";
|
|
13
|
+
import * as i7 from "../../../notification-message/notification-message.component";
|
|
14
|
+
import * as i8 from "@angular/material/progress-spinner";
|
|
14
15
|
import * as i9 from "../../shared/llm-textarea/llm-textarea.component";
|
|
15
16
|
import * as i10 from "@ngx-translate/core";
|
|
16
17
|
export class CreateSummaryComponent {
|
|
@@ -23,11 +24,10 @@ export class CreateSummaryComponent {
|
|
|
23
24
|
get showMissingQuotaMessage() {
|
|
24
25
|
return !this.summaryQuotaLeft && !this.missingQuotaMessageClosed;
|
|
25
26
|
}
|
|
26
|
-
constructor(llmService, llmHelperService, quotaService,
|
|
27
|
+
constructor(llmService, llmHelperService, quotaService, data) {
|
|
27
28
|
this.llmService = llmService;
|
|
28
29
|
this.llmHelperService = llmHelperService;
|
|
29
30
|
this.quotaService = quotaService;
|
|
30
|
-
this.plausibleService = plausibleService;
|
|
31
31
|
this.data = data;
|
|
32
32
|
this.summarizedText = '';
|
|
33
33
|
this.manuallyEditedText = '';
|
|
@@ -43,6 +43,7 @@ export class CreateSummaryComponent {
|
|
|
43
43
|
}
|
|
44
44
|
createSummary() {
|
|
45
45
|
this.isLoading = true;
|
|
46
|
+
this.summaryPlausibleEvent();
|
|
46
47
|
this.subscription = this.llmService
|
|
47
48
|
.summarize({ text: this.manuallyEditedText !== '' ? this.manuallyEditedText : this.initialText, language: this.language })
|
|
48
49
|
.pipe(finalize(() => (this.isLoading = false)))
|
|
@@ -62,16 +63,19 @@ export class CreateSummaryComponent {
|
|
|
62
63
|
cancel() {
|
|
63
64
|
this.subscription.unsubscribe();
|
|
64
65
|
}
|
|
65
|
-
copyEvent() {
|
|
66
|
-
this.plausibleService.summaryCopyEvent();
|
|
67
|
-
}
|
|
68
|
-
dislikeEvent() {
|
|
69
|
-
this.plausibleService.summaryDislikeEvent();
|
|
70
|
-
}
|
|
71
66
|
textEditEvent(text) {
|
|
72
67
|
this.manuallyEditedText = text;
|
|
73
68
|
this.initialText = text;
|
|
74
69
|
}
|
|
70
|
+
copyPlausibleEvent() {
|
|
71
|
+
PlausibleHelper.customEvent('summary', { action: 'copy' });
|
|
72
|
+
}
|
|
73
|
+
dislikePlausibleEvent() {
|
|
74
|
+
PlausibleHelper.customEvent('summary', { action: 'dislike' });
|
|
75
|
+
}
|
|
76
|
+
summaryPlausibleEvent() {
|
|
77
|
+
PlausibleHelper.customEvent('summary', { action: 'summary' });
|
|
78
|
+
}
|
|
75
79
|
refreshQuota(decrease) {
|
|
76
80
|
this.quotaService.getQuotaUsage().pipe(finalize(() => this.setQuotaMessage())).subscribe({
|
|
77
81
|
next: (response) => {
|
|
@@ -93,14 +97,14 @@ export class CreateSummaryComponent {
|
|
|
93
97
|
setQuotaFromLocalStorage(decrease) {
|
|
94
98
|
this.summaryQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(decrease);
|
|
95
99
|
}
|
|
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:
|
|
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)=\"
|
|
100
|
+
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: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
101
|
+
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)=\"copyPlausibleEvent()\" (dislikeEvent)=\"dislikePlausibleEvent()\"></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 <mat-spinner *ngIf=\"isLoading\" [diameter]=\"20\" color=\"accent\" class=\"ml-2\"></mat-spinner>\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}:host ::ng-deep .mdc-button__label{display:flex!important;align-items:center!important}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.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: i6.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i6.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i6.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i6.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i7.NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: ["message", "inline"], outputs: ["buttonClicked", "closeClicked", "linkClicked"] }, { kind: "component", type: i8.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i9.LLMTextareaComponent, selector: "lib-llm-textarea", inputs: ["text", "disabled"], outputs: ["textEditEvent", "dislikeEvent", "copyEvent"] }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }] }); }
|
|
98
102
|
}
|
|
99
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CreateSummaryComponent, decorators: [{
|
|
100
104
|
type: Component,
|
|
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)=\"
|
|
102
|
-
}], ctorParameters: function () { return [{ type: i1.LLMService }, { type: i2.LLMHelperService }, { type: i3.QuotaService }, { type:
|
|
105
|
+
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)=\"copyPlausibleEvent()\" (dislikeEvent)=\"dislikePlausibleEvent()\"></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 <mat-spinner *ngIf=\"isLoading\" [diameter]=\"20\" color=\"accent\" class=\"ml-2\"></mat-spinner>\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}:host ::ng-deep .mdc-button__label{display:flex!important;align-items:center!important}\n"] }]
|
|
106
|
+
}], ctorParameters: function () { return [{ type: i1.LLMService }, { type: i2.LLMHelperService }, { type: i3.QuotaService }, { type: undefined, decorators: [{
|
|
103
107
|
type: Inject,
|
|
104
108
|
args: [MAT_DIALOG_DATA]
|
|
105
109
|
}] }]; } });
|
|
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"]}
|
|
110
|
+
//# 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 { PlausibleHelper } from '../../../plausible';\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    @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    this.summaryPlausibleEvent();\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  textEditEvent(text: string): void {\r\n    this.manuallyEditedText = text;\r\n    this.initialText = text;\r\n  }\r\n\r\n  copyPlausibleEvent(): void {\r\n    PlausibleHelper.customEvent('summary', { action: 'copy' });\r\n  }\r\n  \r\n  dislikePlausibleEvent(): void {\r\n    PlausibleHelper.customEvent('summary', { action: 'dislike' });\r\n  }\r\n\r\n  summaryPlausibleEvent(): void {\r\n    PlausibleHelper.customEvent('summary', { action: 'summary' });\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)=\"copyPlausibleEvent()\" (dislikeEvent)=\"dislikePlausibleEvent()\"></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      <mat-spinner *ngIf=\"isLoading\" [diameter]=\"20\" color=\"accent\" class=\"ml-2\"></mat-spinner>\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { QuotaType } from '../../../services';
|
|
3
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
4
|
+
import { finalize } from 'rxjs';
|
|
5
|
+
import { LLMWritingStyle } from '../../models/llm-writing-style.enum';
|
|
6
|
+
import { PlausibleHelper } from '../../../plausible';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../../services/llm.service";
|
|
9
|
+
import * as i2 from "../../../services";
|
|
10
|
+
import * as i3 from "../../services/llm-helper.service";
|
|
11
|
+
import * as i4 from "@angular/common";
|
|
12
|
+
import * as i5 from "@angular/material/button";
|
|
13
|
+
import * as i6 from "@angular/material/dialog";
|
|
14
|
+
import * as i7 from "@angular/material/form-field";
|
|
15
|
+
import * as i8 from "@angular/material/select";
|
|
16
|
+
import * as i9 from "@angular/material/core";
|
|
17
|
+
import * as i10 from "../../../notification-message/notification-message.component";
|
|
18
|
+
import * as i11 from "@angular/material/tooltip";
|
|
19
|
+
import * as i12 from "@angular/material/progress-spinner";
|
|
20
|
+
import * as i13 from "../../shared/llm-textarea/llm-textarea.component";
|
|
21
|
+
import * as i14 from "@ngx-translate/core";
|
|
22
|
+
export class RephraseComponent {
|
|
23
|
+
get isRephrasingDisabled() {
|
|
24
|
+
return this.isLoading || !this.initialText || !this.rephraseQuotaLeft;
|
|
25
|
+
}
|
|
26
|
+
get defaultErrorMessage() {
|
|
27
|
+
return this.llmHelperService.getDefaultErrorMessage();
|
|
28
|
+
}
|
|
29
|
+
get showMissingQuotaMessage() {
|
|
30
|
+
return !this.rephraseQuotaLeft && !this.missingQuotaMessageClosed;
|
|
31
|
+
}
|
|
32
|
+
constructor(llmService, quotaService, llmHelperService, data) {
|
|
33
|
+
this.llmService = llmService;
|
|
34
|
+
this.quotaService = quotaService;
|
|
35
|
+
this.llmHelperService = llmHelperService;
|
|
36
|
+
this.data = data;
|
|
37
|
+
this.selectedWritingStyle = LLMWritingStyle.GENERAL;
|
|
38
|
+
this.rephrasedText = '';
|
|
39
|
+
this.manuallyEditedText = '';
|
|
40
|
+
this.savedRephrasings = [];
|
|
41
|
+
this.writingStyles = Object.values(LLMWritingStyle);
|
|
42
|
+
this.trialRequestCount = 15;
|
|
43
|
+
this.missingQuotaMessageClosed = false;
|
|
44
|
+
}
|
|
45
|
+
ngOnInit() {
|
|
46
|
+
this.initialText = this.data.text;
|
|
47
|
+
this.subscriptionUrl = this.llmService.llmConfiguration.subscriptionUrl;
|
|
48
|
+
this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();
|
|
49
|
+
this.refreshQuota();
|
|
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
|
+
}
|
|
72
|
+
rephraseText() {
|
|
73
|
+
this.isLoading = true;
|
|
74
|
+
this.writingStylePlausibleEvent();
|
|
75
|
+
this.subscription = this.llmService
|
|
76
|
+
.rephrase({ text: this.manuallyEditedText !== '' ? this.manuallyEditedText : this.initialText, style: this.selectedWritingStyle })
|
|
77
|
+
.pipe(finalize(() => (this.isLoading = false)))
|
|
78
|
+
.subscribe({
|
|
79
|
+
next: (response) => {
|
|
80
|
+
this.rephrasedText = response;
|
|
81
|
+
this.manuallyEditedText = '';
|
|
82
|
+
this.showDefaultErrorMessage = false;
|
|
83
|
+
this.refreshQuota(true);
|
|
84
|
+
},
|
|
85
|
+
error: () => {
|
|
86
|
+
this.showDefaultErrorMessage = true;
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
cancel() {
|
|
91
|
+
this.subscription.unsubscribe();
|
|
92
|
+
}
|
|
93
|
+
textEditEvent(text) {
|
|
94
|
+
this.manuallyEditedText = text;
|
|
95
|
+
this.initialText = text;
|
|
96
|
+
this.rephrasedText = '';
|
|
97
|
+
}
|
|
98
|
+
copyPlausibleEvent() {
|
|
99
|
+
PlausibleHelper.customEvent('rephrase', { action: 'copy' });
|
|
100
|
+
}
|
|
101
|
+
dislikePlausibleEvent() {
|
|
102
|
+
PlausibleHelper.customEvent('rephrase', { action: 'dislike' });
|
|
103
|
+
}
|
|
104
|
+
writingStylePlausibleEvent() {
|
|
105
|
+
PlausibleHelper.customEvent('rephrase', { writingStyle: this.selectedWritingStyle });
|
|
106
|
+
}
|
|
107
|
+
refreshQuota(decrease) {
|
|
108
|
+
this.quotaService.getQuotaUsage().pipe(finalize(() => this.setQuotaMessage())).subscribe({
|
|
109
|
+
next: (response) => {
|
|
110
|
+
const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_CHARACTER_COUNT);
|
|
111
|
+
if (!quota) {
|
|
112
|
+
this.setQuotaFromLocalStorage(decrease);
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
this.rephraseQuotaLeft = quota.quotaRemaining;
|
|
116
|
+
},
|
|
117
|
+
error: () => {
|
|
118
|
+
this.setQuotaFromLocalStorage(decrease);
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
setQuotaMessage() {
|
|
123
|
+
this.showRemainingQuotaMessage = this.rephraseQuotaLeft <= this.trialRequestCount;
|
|
124
|
+
}
|
|
125
|
+
setQuotaFromLocalStorage(decrease) {
|
|
126
|
+
this.rephraseQuotaLeft = this.llmHelperService.setQuotaLocalStorageUsage(decrease);
|
|
127
|
+
}
|
|
128
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RephraseComponent, deps: [{ token: i1.LLMService }, { token: i2.QuotaService }, { token: i3.LLMHelperService }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
129
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RephraseComponent, selector: "lib-rephrase", 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)=\"copyPlausibleEvent()\" (dislikeEvent)=\"dislikePlausibleEvent()\"></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 <mat-spinner *ngIf=\"isLoading\" [diameter]=\"20\" color=\"accent\" class=\"ml-2\"></mat-spinner>\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}:host ::ng-deep .llm-textarea{min-height:220px!important}:host ::ng-deep .desktop .llm-textarea{min-height:410px!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%}:host ::ng-deep .mdc-button__label{display:flex!important;align-items:center!important}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.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: i6.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i6.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i6.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i6.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "component", type: i8.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i9.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i10.NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: ["message", "inline"], outputs: ["buttonClicked", "closeClicked", "linkClicked"] }, { kind: "directive", type: i11.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i12.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i13.LLMTextareaComponent, selector: "lib-llm-textarea", inputs: ["text", "disabled"], outputs: ["textEditEvent", "dislikeEvent", "copyEvent"] }, { kind: "pipe", type: i4.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }] }); }
|
|
130
|
+
}
|
|
131
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RephraseComponent, decorators: [{
|
|
132
|
+
type: Component,
|
|
133
|
+
args: [{ selector: 'lib-rephrase', 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)=\"copyPlausibleEvent()\" (dislikeEvent)=\"dislikePlausibleEvent()\"></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 <mat-spinner *ngIf=\"isLoading\" [diameter]=\"20\" color=\"accent\" class=\"ml-2\"></mat-spinner>\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}:host ::ng-deep .llm-textarea{min-height:220px!important}:host ::ng-deep .desktop .llm-textarea{min-height:410px!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%}:host ::ng-deep .mdc-button__label{display:flex!important;align-items:center!important}\n"] }]
|
|
134
|
+
}], ctorParameters: function () { return [{ type: i1.LLMService }, { type: i2.QuotaService }, { type: i3.LLMHelperService }, { type: undefined, decorators: [{
|
|
135
|
+
type: Inject,
|
|
136
|
+
args: [MAT_DIALOG_DATA]
|
|
137
|
+
}] }]; } });
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rephrase.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/llm/components/rephrase/rephrase.component.ts","../../../../../../../projects/ngx-common/src/lib/llm/components/rephrase/rephrase.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 { PlausibleHelper } from '../../../plausible';\r\n\r\n@Component({\r\n  selector: 'lib-rephrase',\r\n  templateUrl: './rephrase.component.html',\r\n  styleUrls: ['./rephrase.component.scss']\r\n})\r\nexport class RephraseComponent implements OnInit {\r\n  isLoading!: boolean;\r\n  showDefaultErrorMessage!: boolean;\r\n  showRemainingQuotaMessage!: 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    @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    this.writingStylePlausibleEvent();\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  textEditEvent(text: string): void {\r\n    this.manuallyEditedText = text;\r\n    this.initialText = text;\r\n    this.rephrasedText = '';\r\n  }\r\n\r\n  copyPlausibleEvent(): void {\r\n    PlausibleHelper.customEvent('rephrase', { action: 'copy' });\r\n  }\r\n  \r\n  dislikePlausibleEvent(): void {\r\n    PlausibleHelper.customEvent('rephrase', { action: 'dislike' });\r\n  }\r\n\r\n  private writingStylePlausibleEvent(): void {\r\n    PlausibleHelper.customEvent('rephrase', { writingStyle: this.selectedWritingStyle });\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)=\"copyPlausibleEvent()\" (dislikeEvent)=\"dislikePlausibleEvent()\"></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      <mat-spinner *ngIf=\"isLoading\" [diameter]=\"20\" color=\"accent\" class=\"ml-2\"></mat-spinner>\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -1,27 +1,29 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
2
|
import { LLMActions } from './models/llm-actions.enum';
|
|
3
|
-
import {
|
|
3
|
+
import { RephraseComponent } from './components/rephrase/rephrase.component';
|
|
4
4
|
import { CreateSummaryComponent } from './components/create-summary/create-summary.component';
|
|
5
5
|
import { ResolutionHelper } from '../helpers';
|
|
6
6
|
import * as icons from './icons';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
import * as i1 from "@angular/material/dialog";
|
|
9
9
|
import * as i2 from "../services";
|
|
10
|
-
import * as i3 from "@angular/
|
|
11
|
-
import * as i4 from "@angular/material/
|
|
12
|
-
import * as i5 from "@angular/material/
|
|
13
|
-
import * as i6 from "@angular/material/
|
|
14
|
-
import * as i7 from "@
|
|
15
|
-
import * as i8 from "@ngx-translate/core";
|
|
10
|
+
import * as i3 from "@angular/material/button";
|
|
11
|
+
import * as i4 from "@angular/material/icon";
|
|
12
|
+
import * as i5 from "@angular/material/menu";
|
|
13
|
+
import * as i6 from "@angular/material/tooltip";
|
|
14
|
+
import * as i7 from "@ngx-translate/core";
|
|
16
15
|
export class LLMComponent {
|
|
17
16
|
get isTextSummarizable() {
|
|
18
17
|
return this.text.length > 100;
|
|
19
18
|
}
|
|
20
|
-
|
|
19
|
+
get isTargetLanguageRephrasable() {
|
|
20
|
+
return this.rephrasableLanguagesCodeList.includes(this.languageService.removeRegionFromLanguageCode(this.language));
|
|
21
|
+
}
|
|
22
|
+
constructor(dialog, iconService, languageService) {
|
|
21
23
|
this.dialog = dialog;
|
|
22
24
|
this.iconService = iconService;
|
|
25
|
+
this.languageService = languageService;
|
|
23
26
|
this.rephrasableLanguagesCodeList = ['en'];
|
|
24
|
-
this.llmActions = Object.values(LLMActions);
|
|
25
27
|
this.llmAction = LLMActions;
|
|
26
28
|
this.iconService.registerIcons(icons);
|
|
27
29
|
}
|
|
@@ -37,18 +39,18 @@ export class LLMComponent {
|
|
|
37
39
|
getComponentByLLMAction(action) {
|
|
38
40
|
switch (action) {
|
|
39
41
|
case LLMActions.REPHRASE:
|
|
40
|
-
return
|
|
42
|
+
return RephraseComponent;
|
|
41
43
|
case LLMActions.SUMMARY:
|
|
42
44
|
return CreateSummaryComponent;
|
|
43
45
|
}
|
|
44
46
|
}
|
|
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 }); }
|
|
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"
|
|
47
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LLMComponent, deps: [{ token: i1.MatDialog }, { token: i2.IconService }, { token: i2.LanguageTranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
48
|
+
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" }, ngImport: i0, template: "<button\r\n [disabled]=\"isMenuDisabled\"\r\n [matTooltip]=\"'LLM.MENU_TOOLTIP' | translate\"\r\n mat-icon-button\r\n [matMenuTriggerFor]=\"menu\"\r\n>\r\n <mat-icon svgIcon=\"llm_menu\"></mat-icon>\r\n</button>\r\n\r\n<mat-menu #menu=\"matMenu\">\r\n <div [matTooltip]=\"!isTextSummarizable ? ('LLM.MENU_SUMMARY_DISABLED_TOOLTIP' | translate) : ''\">\r\n <button\r\n mat-menu-item\r\n [disabled]=\"!isTextSummarizable\"\r\n (click)=\"openLLMModal(llmAction.SUMMARY)\"\r\n >\r\n {{ \"LLM.SUMMARY\" | translate }}\r\n </button>\r\n </div>\r\n\r\n <div [matTooltip]=\"!isTargetLanguageRephrasable ? ('LLM.MENU_REPHRASE_DISABLED_TOOLTIP' | translate) : ''\">\r\n <button\r\n mat-menu-item\r\n [disabled]=\"!isTargetLanguageRephrasable\"\r\n (click)=\"openLLMModal(llmAction.REPHRASE)\"\r\n >\r\n {{ \"LLM.REPHRASE\" | translate }}\r\n </button>\r\n </div>\r\n</mat-menu>\r\n", styles: [""], dependencies: [{ kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i5.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i5.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
|
|
47
49
|
}
|
|
48
50
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LLMComponent, decorators: [{
|
|
49
51
|
type: Component,
|
|
50
|
-
args: [{ selector: 'lib-llm', template: "<button
|
|
51
|
-
}], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i2.IconService }]; }, propDecorators: { text: [{
|
|
52
|
+
args: [{ selector: 'lib-llm', template: "<button\r\n [disabled]=\"isMenuDisabled\"\r\n [matTooltip]=\"'LLM.MENU_TOOLTIP' | translate\"\r\n mat-icon-button\r\n [matMenuTriggerFor]=\"menu\"\r\n>\r\n <mat-icon svgIcon=\"llm_menu\"></mat-icon>\r\n</button>\r\n\r\n<mat-menu #menu=\"matMenu\">\r\n <div [matTooltip]=\"!isTextSummarizable ? ('LLM.MENU_SUMMARY_DISABLED_TOOLTIP' | translate) : ''\">\r\n <button\r\n mat-menu-item\r\n [disabled]=\"!isTextSummarizable\"\r\n (click)=\"openLLMModal(llmAction.SUMMARY)\"\r\n >\r\n {{ \"LLM.SUMMARY\" | translate }}\r\n </button>\r\n </div>\r\n\r\n <div [matTooltip]=\"!isTargetLanguageRephrasable ? ('LLM.MENU_REPHRASE_DISABLED_TOOLTIP' | translate) : ''\">\r\n <button\r\n mat-menu-item\r\n [disabled]=\"!isTargetLanguageRephrasable\"\r\n (click)=\"openLLMModal(llmAction.REPHRASE)\"\r\n >\r\n {{ \"LLM.REPHRASE\" | translate }}\r\n </button>\r\n </div>\r\n</mat-menu>\r\n" }]
|
|
53
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i2.IconService }, { type: i2.LanguageTranslateService }]; }, propDecorators: { text: [{
|
|
52
54
|
type: Input
|
|
53
55
|
}], language: [{
|
|
54
56
|
type: Input
|
|
@@ -56,7 +58,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
56
58
|
type: Input
|
|
57
59
|
}], rephrasableLanguagesCodeList: [{
|
|
58
60
|
type: Input
|
|
59
|
-
}], llmActions: [{
|
|
60
|
-
type: Input
|
|
61
61
|
}] } });
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV2RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUM5RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFHOUMsT0FBTyxLQUFLLEtBQUssTUFBTSxTQUFTLENBQUM7Ozs7Ozs7OztBQU9qQyxNQUFNLE9BQU8sWUFBWTtJQVF2QixJQUFJLGtCQUFrQjtRQUNwQixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLEdBQUcsQ0FBQztJQUNoQyxDQUFDO0lBRUQsSUFBSSwyQkFBMkI7UUFDN0IsT0FBTyxJQUFJLENBQUMsNEJBQTRCLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsNEJBQTRCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDdEgsQ0FBQztJQUVELFlBQW1CLE1BQWlCLEVBQW1CLFdBQXdCLEVBQW1CLGVBQXlDO1FBQXhILFdBQU0sR0FBTixNQUFNLENBQVc7UUFBbUIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBbUIsb0JBQWUsR0FBZixlQUFlLENBQTBCO1FBWmxJLGlDQUE0QixHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFdEMsY0FBUyxHQUFHLFVBQVUsQ0FBQztRQVc5QixJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsWUFBWSxDQUFDLE1BQWtCO1FBQzdCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUNyRCxRQUFRLEVBQUUsZ0JBQWdCLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsT0FBTztZQUMzRCxJQUFJLEVBQUU7Z0JBQ0osSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO2dCQUNmLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTthQUN4QjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFTyx1QkFBdUIsQ0FBQyxNQUFrQjtRQUNoRCxRQUFRLE1BQU0sRUFBRTtZQUNkLEtBQUssVUFBVSxDQUFDLFFBQVE7Z0JBQ3RCLE9BQU8saUJBQWlCLENBQUM7WUFDM0IsS0FBSyxVQUFVLENBQUMsT0FBTztnQkFDckIsT0FBTyxzQkFBc0IsQ0FBQztTQUNqQztJQUNILENBQUM7K0dBckNVLFlBQVk7bUdBQVosWUFBWSwrTENmekIsNDZCQThCQTs7NEZEZmEsWUFBWTtrQkFMeEIsU0FBUzsrQkFDRSxTQUFTO2lLQUtWLElBQUk7c0JBQVosS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csNEJBQTRCO3NCQUFwQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBMTE1BY3Rpb25zIH0gZnJvbSAnLi9tb2RlbHMvbGxtLWFjdGlvbnMuZW51bSc7XHJcbmltcG9ydCB7IE1hdERpYWxvZyB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IFJlcGhyYXNlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3JlcGhyYXNlL3JlcGhyYXNlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENyZWF0ZVN1bW1hcnlDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvY3JlYXRlLXN1bW1hcnkvY3JlYXRlLXN1bW1hcnkuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUmVzb2x1dGlvbkhlbHBlciB9IGZyb20gJy4uL2hlbHBlcnMnO1xyXG5pbXBvcnQgeyBJY29uU2VydmljZSwgTGFuZ3VhZ2VUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMnO1xyXG5pbXBvcnQgeyBDb21wb25lbnRUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3BvcnRhbCc7XHJcbmltcG9ydCAqIGFzIGljb25zIGZyb20gJy4vaWNvbnMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdsaWItbGxtJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vbGxtLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9sbG0uY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIExMTUNvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgdGV4dCE6IHN0cmluZztcclxuICBASW5wdXQoKSBsYW5ndWFnZSE6IHN0cmluZztcclxuICBASW5wdXQoKSBpc01lbnVEaXNhYmxlZCE6IGJvb2xlYW47XHJcbiAgQElucHV0KCkgcmVwaHJhc2FibGVMYW5ndWFnZXNDb2RlTGlzdCA9IFsnZW4nXTtcclxuXHJcbiAgcmVhZG9ubHkgbGxtQWN0aW9uID0gTExNQWN0aW9ucztcclxuXHJcbiAgZ2V0IGlzVGV4dFN1bW1hcml6YWJsZSgpIHtcclxuICAgIHJldHVybiB0aGlzLnRleHQubGVuZ3RoID4gMTAwO1xyXG4gIH1cclxuXHJcbiAgZ2V0IGlzVGFyZ2V0TGFuZ3VhZ2VSZXBocmFzYWJsZSgpIHtcclxuICAgIHJldHVybiB0aGlzLnJlcGhyYXNhYmxlTGFuZ3VhZ2VzQ29kZUxpc3QuaW5jbHVkZXModGhpcy5sYW5ndWFnZVNlcnZpY2UucmVtb3ZlUmVnaW9uRnJvbUxhbmd1YWdlQ29kZSh0aGlzLmxhbmd1YWdlKSk7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihwdWJsaWMgZGlhbG9nOiBNYXREaWFsb2csIHByaXZhdGUgcmVhZG9ubHkgaWNvblNlcnZpY2U6IEljb25TZXJ2aWNlLCBwcml2YXRlIHJlYWRvbmx5IGxhbmd1YWdlU2VydmljZTogTGFuZ3VhZ2VUcmFuc2xhdGVTZXJ2aWNlKSB7XHJcbiAgICB0aGlzLmljb25TZXJ2aWNlLnJlZ2lzdGVySWNvbnMoaWNvbnMpO1xyXG4gIH1cclxuXHJcbiAgb3BlbkxMTU1vZGFsKGFjdGlvbjogTExNQWN0aW9ucyk6IHZvaWQge1xyXG4gICAgdGhpcy5kaWFsb2cub3Blbih0aGlzLmdldENvbXBvbmVudEJ5TExNQWN0aW9uKGFjdGlvbiksIHtcclxuICAgICAgbWluV2lkdGg6IFJlc29sdXRpb25IZWxwZXIuaXNNb2JpbGVSZXMoKSA/ICcxMDAlJyA6ICc4MDBweCcsXHJcbiAgICAgIGRhdGE6IHtcclxuICAgICAgICB0ZXh0OiB0aGlzLnRleHQsXHJcbiAgICAgICAgbGFuZ3VhZ2U6IHRoaXMubGFuZ3VhZ2VcclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGdldENvbXBvbmVudEJ5TExNQWN0aW9uKGFjdGlvbjogTExNQWN0aW9ucyk6IENvbXBvbmVudFR5cGU8UmVwaHJhc2VDb21wb25lbnQgfCBDcmVhdGVTdW1tYXJ5Q29tcG9uZW50PiB7XHJcbiAgICBzd2l0Y2ggKGFjdGlvbikge1xyXG4gICAgICBjYXNlIExMTUFjdGlvbnMuUkVQSFJBU0U6XHJcbiAgICAgICAgcmV0dXJuIFJlcGhyYXNlQ29tcG9uZW50O1xyXG4gICAgICBjYXNlIExMTUFjdGlvbnMuU1VNTUFSWTpcclxuICAgICAgICByZXR1cm4gQ3JlYXRlU3VtbWFyeUNvbXBvbmVudDtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPGJ1dHRvblxyXG4gIFtkaXNhYmxlZF09XCJpc01lbnVEaXNhYmxlZFwiXHJcbiAgW21hdFRvb2x0aXBdPVwiJ0xMTS5NRU5VX1RPT0xUSVAnIHwgdHJhbnNsYXRlXCJcclxuICBtYXQtaWNvbi1idXR0b25cclxuICBbbWF0TWVudVRyaWdnZXJGb3JdPVwibWVudVwiXHJcbj5cclxuICA8bWF0LWljb24gc3ZnSWNvbj1cImxsbV9tZW51XCI+PC9tYXQtaWNvbj5cclxuPC9idXR0b24+XHJcblxyXG48bWF0LW1lbnUgI21lbnU9XCJtYXRNZW51XCI+XHJcbiAgPGRpdiBbbWF0VG9vbHRpcF09XCIhaXNUZXh0U3VtbWFyaXphYmxlID8gKCdMTE0uTUVOVV9TVU1NQVJZX0RJU0FCTEVEX1RPT0xUSVAnIHwgdHJhbnNsYXRlKSA6ICcnXCI+XHJcbiAgICA8YnV0dG9uXHJcbiAgICAgIG1hdC1tZW51LWl0ZW1cclxuICAgICAgW2Rpc2FibGVkXT1cIiFpc1RleHRTdW1tYXJpemFibGVcIlxyXG4gICAgICAoY2xpY2spPVwib3BlbkxMTU1vZGFsKGxsbUFjdGlvbi5TVU1NQVJZKVwiXHJcbiAgICA+XHJcbiAgICAgIHt7IFwiTExNLlNVTU1BUllcIiB8IHRyYW5zbGF0ZSB9fVxyXG4gICAgPC9idXR0b24+XHJcbiAgPC9kaXY+XHJcblxyXG4gIDxkaXYgW21hdFRvb2x0aXBdPVwiIWlzVGFyZ2V0TGFuZ3VhZ2VSZXBocmFzYWJsZSA/ICgnTExNLk1FTlVfUkVQSFJBU0VfRElTQUJMRURfVE9PTFRJUCcgfCB0cmFuc2xhdGUpIDogJydcIj5cclxuICAgIDxidXR0b25cclxuICAgICAgbWF0LW1lbnUtaXRlbVxyXG4gICAgICBbZGlzYWJsZWRdPVwiIWlzVGFyZ2V0TGFuZ3VhZ2VSZXBocmFzYWJsZVwiXHJcbiAgICAgIChjbGljayk9XCJvcGVuTExNTW9kYWwobGxtQWN0aW9uLlJFUEhSQVNFKVwiXHJcbiAgICA+XHJcbiAgICAgIHt7IFwiTExNLlJFUEhSQVNFXCIgfCB0cmFuc2xhdGUgfX1cclxuICAgIDwvYnV0dG9uPlxyXG4gIDwvZGl2PlxyXG48L21hdC1tZW51PlxyXG4iXX0=
|
|
@@ -5,7 +5,7 @@ import { MatButtonModule } from '@angular/material/button';
|
|
|
5
5
|
import { MatIconModule } from '@angular/material/icon';
|
|
6
6
|
import { MatMenuModule } from '@angular/material/menu';
|
|
7
7
|
import { TranslateModule } from '@ngx-translate/core';
|
|
8
|
-
import {
|
|
8
|
+
import { RephraseComponent } from './components/rephrase/rephrase.component';
|
|
9
9
|
import { CreateSummaryComponent } from './components/create-summary/create-summary.component';
|
|
10
10
|
import { MatDialogModule } from '@angular/material/dialog';
|
|
11
11
|
import { ClipboardModule } from '@angular/cdk/clipboard';
|
|
@@ -15,11 +15,12 @@ import { MatSelectModule } from '@angular/material/select';
|
|
|
15
15
|
import { NotificationMessageModule } from '../notification-message';
|
|
16
16
|
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
17
17
|
import { FlexLayoutModule } from '@angular/flex-layout';
|
|
18
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
18
19
|
import * as i0 from "@angular/core";
|
|
19
20
|
export class LLMModule {
|
|
20
21
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LLMModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
21
22
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: LLMModule, declarations: [LLMComponent,
|
|
22
|
-
|
|
23
|
+
RephraseComponent,
|
|
23
24
|
CreateSummaryComponent,
|
|
24
25
|
LLMTextareaComponent], imports: [CommonModule,
|
|
25
26
|
MatButtonModule,
|
|
@@ -33,7 +34,8 @@ export class LLMModule {
|
|
|
33
34
|
MatSelectModule,
|
|
34
35
|
NotificationMessageModule,
|
|
35
36
|
MatTooltipModule,
|
|
36
|
-
FlexLayoutModule
|
|
37
|
+
FlexLayoutModule,
|
|
38
|
+
MatProgressSpinnerModule], exports: [LLMComponent] }); }
|
|
37
39
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LLMModule, imports: [CommonModule,
|
|
38
40
|
MatButtonModule,
|
|
39
41
|
MatIconModule,
|
|
@@ -46,14 +48,15 @@ export class LLMModule {
|
|
|
46
48
|
MatSelectModule,
|
|
47
49
|
NotificationMessageModule,
|
|
48
50
|
MatTooltipModule,
|
|
49
|
-
FlexLayoutModule
|
|
51
|
+
FlexLayoutModule,
|
|
52
|
+
MatProgressSpinnerModule] }); }
|
|
50
53
|
}
|
|
51
54
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LLMModule, decorators: [{
|
|
52
55
|
type: NgModule,
|
|
53
56
|
args: [{
|
|
54
57
|
declarations: [
|
|
55
58
|
LLMComponent,
|
|
56
|
-
|
|
59
|
+
RephraseComponent,
|
|
57
60
|
CreateSummaryComponent,
|
|
58
61
|
LLMTextareaComponent,
|
|
59
62
|
],
|
|
@@ -70,9 +73,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
70
73
|
MatSelectModule,
|
|
71
74
|
NotificationMessageModule,
|
|
72
75
|
MatTooltipModule,
|
|
73
|
-
FlexLayoutModule
|
|
76
|
+
FlexLayoutModule,
|
|
77
|
+
MatProgressSpinnerModule
|
|
74
78
|
],
|
|
75
79
|
exports: [LLMComponent],
|
|
76
80
|
}]
|
|
77
81
|
}] });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBQzlGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7QUEyQjlFLE1BQU0sT0FBTyxTQUFTOytHQUFULFNBQVM7Z0hBQVQsU0FBUyxpQkF2QmxCLFlBQVk7WUFDWixpQkFBaUI7WUFDakIsc0JBQXNCO1lBQ3RCLG9CQUFvQixhQUdwQixZQUFZO1lBQ1osZUFBZTtZQUNmLGFBQWE7WUFDYixhQUFhO1lBQ2IsZUFBZTtZQUNmLGVBQWU7WUFDZixlQUFlO1lBQ2YsV0FBVztZQUNYLG1CQUFtQjtZQUNuQixlQUFlO1lBQ2YseUJBQXlCO1lBQ3pCLGdCQUFnQjtZQUNoQixnQkFBZ0I7WUFDaEIsd0JBQXdCLGFBRWhCLFlBQVk7Z0hBRVgsU0FBUyxZQWpCbEIsWUFBWTtZQUNaLGVBQWU7WUFDZixhQUFhO1lBQ2IsYUFBYTtZQUNiLGVBQWU7WUFDZixlQUFlO1lBQ2YsZUFBZTtZQUNmLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsZUFBZTtZQUNmLHlCQUF5QjtZQUN6QixnQkFBZ0I7WUFDaEIsZ0JBQWdCO1lBQ2hCLHdCQUF3Qjs7NEZBSWYsU0FBUztrQkF6QnJCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLFlBQVk7d0JBQ1osaUJBQWlCO3dCQUNqQixzQkFBc0I7d0JBQ3RCLG9CQUFvQjtxQkFDckI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osZUFBZTt3QkFDZixhQUFhO3dCQUNiLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGVBQWU7d0JBQ2YsV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLGVBQWU7d0JBQ2YseUJBQXlCO3dCQUN6QixnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFDaEIsd0JBQXdCO3FCQUN6QjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7aUJBQ3hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTExNQ29tcG9uZW50IH0gZnJvbSAnLi9sbG0uY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBNYXRNZW51TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbWVudSc7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5pbXBvcnQgeyBSZXBocmFzZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9yZXBocmFzZS9yZXBocmFzZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBDcmVhdGVTdW1tYXJ5Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2NyZWF0ZS1zdW1tYXJ5L2NyZWF0ZS1zdW1tYXJ5LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdERpYWxvZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IENsaXBib2FyZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jbGlwYm9hcmQnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTExNVGV4dGFyZWFDb21wb25lbnQgfSBmcm9tICcuL3NoYXJlZC9sbG0tdGV4dGFyZWEvbGxtLXRleHRhcmVhLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdFNlbGVjdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XHJcbmltcG9ydCB7IE5vdGlmaWNhdGlvbk1lc3NhZ2VNb2R1bGUgfSBmcm9tICcuLi9ub3RpZmljYXRpb24tbWVzc2FnZSc7XHJcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcclxuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2ZsZXgtbGF5b3V0JztcclxuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3Mtc3Bpbm5lcic7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgTExNQ29tcG9uZW50LFxyXG4gICAgUmVwaHJhc2VDb21wb25lbnQsXHJcbiAgICBDcmVhdGVTdW1tYXJ5Q29tcG9uZW50LFxyXG4gICAgTExNVGV4dGFyZWFDb21wb25lbnQsXHJcbiAgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBNYXRCdXR0b25Nb2R1bGUsXHJcbiAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgTWF0TWVudU1vZHVsZSxcclxuICAgIFRyYW5zbGF0ZU1vZHVsZSxcclxuICAgIE1hdERpYWxvZ01vZHVsZSxcclxuICAgIENsaXBib2FyZE1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIE1hdFNlbGVjdE1vZHVsZSxcclxuICAgIE5vdGlmaWNhdGlvbk1lc3NhZ2VNb2R1bGUsXHJcbiAgICBNYXRUb29sdGlwTW9kdWxlLFxyXG4gICAgRmxleExheW91dE1vZHVsZSxcclxuICAgIE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZVxyXG4gIF0sXHJcbiAgZXhwb3J0czogW0xMTUNvbXBvbmVudF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMTE1Nb2R1bGUge31cclxuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLWNvbmZpZ3VyYXRpb24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvbGxtL21vZGVscy9sbG0tY29uZmlndXJhdGlvbi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBMTE1Db25maWd1cmF0aW9uIHtcclxuICBzZXJ2aWNlVXJsOiBzdHJpbmc7XHJcbiAgc3Vic2NyaXB0aW9uVXJsOiBzdHJpbmc7XHJcbiAgc3VwcG9ydEVtYWlsOiBzdHJpbmc7XHJcbiAgeEFwaUtleTogc3RyaW5nLFxyXG4gIGFwcElkOiBzdHJpbmcsXHJcbn0iXX0=
|