@tilde-nlp/ngx-common 4.1.21 → 4.1.22
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 +5 -1
- package/esm2022/lib/llm/components/rephrase-translation/rephrase-translation.component.mjs +5 -1
- package/esm2022/lib/llm/models/llm-configuration.model.mjs +1 -1
- package/esm2022/lib/llm/services/llm.service.mjs +6 -3
- package/fesm2022/tilde-nlp-ngx-common.mjs +12 -2
- package/fesm2022/tilde-nlp-ngx-common.mjs.map +1 -1
- package/lib/llm/models/llm-configuration.model.d.ts +3 -0
- package/package.json +1 -1
|
@@ -49,6 +49,10 @@ export class CreateSummaryComponent {
|
|
|
49
49
|
this.llmService.cancelRequest();
|
|
50
50
|
}
|
|
51
51
|
refreshQuota(decrease) {
|
|
52
|
+
if (this.llmService.llmConfiguration.isWebComponent) {
|
|
53
|
+
this.summaryQuotaLeft = this.llmService.setQuotaLocalStorageUsage(this.summaryQuotaLocalStorageKey, decrease);
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
52
56
|
this.quotaService.getQuotaUsage().subscribe({
|
|
53
57
|
next: (response) => {
|
|
54
58
|
const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_REQUESTS);
|
|
@@ -70,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
70
74
|
type: Inject,
|
|
71
75
|
args: [MAT_DIALOG_DATA]
|
|
72
76
|
}] }]; } });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# 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 { Llm } from '../../models/llm.model';\r\nimport { LlmService } from '../../services/llm.service';\r\nimport { finalize } from 'rxjs';\r\nimport { QuotaService, QuotaType } from '../../../services';\r\nimport { NotificationMessage } from '../../../notification-message';\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  text!: string;\r\n  language!: string;\r\n  summaryQuotaLeft!: number;\r\n  subscriptionUrl!: string;\r\n\r\n  reachedQuotaMessage!: NotificationMessage;\r\n\r\n  private readonly trialRequestCount = 15;\r\n  private readonly summaryQuotaLocalStorageKey = 'LLM_SUMMARY_USAGE_KEY';\r\n\r\n  get showRemainingQuotaMessage() {\r\n    return this.summaryQuotaLeft <= this.trialRequestCount;\r\n  }\r\n\r\n  constructor(\r\n    private readonly llmService: LlmService,\r\n    private readonly quotaService: QuotaService,\r\n    @Inject(MAT_DIALOG_DATA) private data: Llm\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.llmService.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.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.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.llmService.cancelRequest();\r\n  }\r\n\r\n  private refreshQuota(decrease?: boolean): void {\r\n    if (this.llmService.llmConfiguration.isWebComponent) {\r\n      this.summaryQuotaLeft = this.llmService.setQuotaLocalStorageUsage(this.summaryQuotaLocalStorageKey, decrease);\r\n      return;\r\n    }\r\n\r\n    this.quotaService.getQuotaUsage().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.llmService.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","<h1 mat-dialog-title>{{ \"LLM.SUMMARY_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n  <p class=\"text-m\">{{ \"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\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"d-flex justify-content-between mx-3 mb-2\" 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-100]=\"!showRemainingQuotaMessage\" class=\"d-flex justify-content-end\">\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]=\"isLoading || !text || !summaryQuotaLeft\"\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"]}
|
|
@@ -54,6 +54,10 @@ export class RephraseTranslationComponent {
|
|
|
54
54
|
this.llmService.cancelRequest();
|
|
55
55
|
}
|
|
56
56
|
refreshQuota(decrease) {
|
|
57
|
+
if (this.llmService.llmConfiguration.isWebComponent) {
|
|
58
|
+
this.rephraseQuotaLeft = this.llmService.setQuotaLocalStorageUsage(this.rephraseQuotaLocalStorageKey, decrease);
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
57
61
|
this.quotaService.getQuotaUsage().subscribe({
|
|
58
62
|
next: (response) => {
|
|
59
63
|
const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_CHARACTER_COUNT);
|
|
@@ -75,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
75
79
|
type: Inject,
|
|
76
80
|
args: [MAT_DIALOG_DATA]
|
|
77
81
|
}] }]; } });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rephrase-translation.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/llm/components/rephrase-translation/rephrase-translation.component.ts","../../../../../../../projects/ngx-common/src/lib/llm/components/rephrase-translation/rephrase-translation.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAE1D,OAAO,EAAgB,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE5D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;;;;;;AAQtE,MAAM,OAAO,4BAA4B;IAevC,IAAI,yBAAyB;QAC3B,OAAO,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC;IAC1D,CAAC;IAED,YACmB,UAAsB,EACtB,YAA0B,EACV,IAAS;QAFzB,eAAU,GAAV,UAAU,CAAY;QACtB,iBAAY,GAAZ,YAAY,CAAc;QACV,SAAI,GAAJ,IAAI,CAAK;QAhB5C,yBAAoB,GAAG,eAAe,CAAC,OAAO,CAAC;QAItC,kBAAa,GAAG,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QAEvC,sBAAiB,GAAG,EAAE,CAAC;QACvB,iCAA4B,GAAG,wBAAwB,CAAC;IAUtE,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,eAAe,CAAC;QACxE,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,UAAU,CAAC,sBAAsB,EAAE,CAAC;QACpE,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QAEtB,IAAI,CAAC,UAAU;aACZ,QAAQ,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,oBAAoB,EAAE,CAAC;aAC/D,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC;aAC9C,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;gBACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YAC1B,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC/B,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;IAClC,CAAC;IAEO,YAAY,CAAC,QAAkB;QACrC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC;YAC1C,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE;gBACjB,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,mBAAmB,CAAC,CAAC;gBAE9F,IAAI,CAAC,KAAK,EAAE;oBACV,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAAC,IAAI,CAAC,4BAA4B,EAAE,QAAQ,CAAC,CAAC;oBAChH,OAAO;iBACR;gBAED,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,cAAc,CAAC;YAChD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;+GAlEU,4BAA4B,wEAsB7B,eAAe;mGAtBd,4BAA4B,gECdzC,imFA4DA;;4FD9Ca,4BAA4B;kBALxC,SAAS;+BACE,0BAA0B;;0BA0BjC,MAAM;2BAAC,eAAe","sourcesContent":["import { Component, Inject, OnInit } from '@angular/core';\r\nimport { LlmService } from '../../services/llm.service';\r\nimport { QuotaService, QuotaType } from '../../../services';\r\nimport { Llm } from '../../models/llm.model';\r\nimport { MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { finalize } from 'rxjs';\r\nimport { LlmWritingStyle } from '../../models/llm-writing-style.enum';\r\nimport { NotificationMessage } from '../../../notification-message';\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  text!: string;\r\n  rephraseQuotaLeft!: number;\r\n  subscriptionUrl!: string;\r\n  selectedWritingStyle = LlmWritingStyle.GENERAL;\r\n\r\n  reachedQuotaMessage!: NotificationMessage;\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 showRemainingQuotaMessage() {\r\n    return this.rephraseQuotaLeft <= this.trialRequestCount;\r\n  }\r\n\r\n  constructor(\r\n    private readonly llmService: LlmService,\r\n    private readonly quotaService: QuotaService,\r\n    @Inject(MAT_DIALOG_DATA) private data: Llm\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.llmService.getReachedQuotaMessage();\r\n    this.refreshQuota();\r\n  }\r\n\r\n  rephraseText(): void {\r\n    this.isLoading = true;\r\n\r\n    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.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.llmService.cancelRequest();\r\n  }\r\n\r\n  private refreshQuota(decrease?: boolean): void {\r\n    this.quotaService.getQuotaUsage().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.llmService.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","<h1 mat-dialog-title>{{ \"LLM.REPHRASE_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n  <p class=\"text-m\">{{ \"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-100 mt-3\" 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=\"d-flex align-items-center 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 ml-1 info-icon\"\r\n      matTooltipClass=\"multiline-tooltip\"\r\n      matTooltipPosition=\"above\" \r\n      [matTooltip]=\"'LLM.REPHRASE_MODAL.WRITING_STYLES.TOOLTIP' | 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\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"d-flex justify-content-between mx-3 mb-2\" 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-100]=\"!showRemainingQuotaMessage\" class=\"d-flex justify-content-end\">\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]=\"isLoading || !text || !rephraseQuotaLeft\"\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"]}
|
|
82
|
+
//# 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 { Llm } from '../../models/llm.model';\r\nimport { MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { finalize } from 'rxjs';\r\nimport { LlmWritingStyle } from '../../models/llm-writing-style.enum';\r\nimport { NotificationMessage } from '../../../notification-message';\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  text!: string;\r\n  rephraseQuotaLeft!: number;\r\n  subscriptionUrl!: string;\r\n  selectedWritingStyle = LlmWritingStyle.GENERAL;\r\n\r\n  reachedQuotaMessage!: NotificationMessage;\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 showRemainingQuotaMessage() {\r\n    return this.rephraseQuotaLeft <= this.trialRequestCount;\r\n  }\r\n\r\n  constructor(\r\n    private readonly llmService: LlmService,\r\n    private readonly quotaService: QuotaService,\r\n    @Inject(MAT_DIALOG_DATA) private data: Llm\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.llmService.getReachedQuotaMessage();\r\n    this.refreshQuota();\r\n  }\r\n\r\n  rephraseText(): void {\r\n    this.isLoading = true;\r\n\r\n    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.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.llmService.cancelRequest();\r\n  }\r\n\r\n  private refreshQuota(decrease?: boolean): void {\r\n    if (this.llmService.llmConfiguration.isWebComponent) {\r\n      this.rephraseQuotaLeft = this.llmService.setQuotaLocalStorageUsage(this.rephraseQuotaLocalStorageKey, decrease);\r\n      return;\r\n    }\r\n\r\n    this.quotaService.getQuotaUsage().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.llmService.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","<h1 mat-dialog-title>{{ \"LLM.REPHRASE_MODAL.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n  <p class=\"text-m\">{{ \"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-100 mt-3\" 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=\"d-flex align-items-center 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 ml-1 info-icon\"\r\n      matTooltipClass=\"multiline-tooltip\"\r\n      matTooltipPosition=\"above\" \r\n      [matTooltip]=\"'LLM.REPHRASE_MODAL.WRITING_STYLES.TOOLTIP' | 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\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"d-flex justify-content-between mx-3 mb-2\" 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-100]=\"!showRemainingQuotaMessage\" class=\"d-flex justify-content-end\">\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]=\"isLoading || !text || !rephraseQuotaLeft\"\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"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLWNvbmZpZ3VyYXRpb24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvbGxtL21vZGVscy9sbG0tY29uZmlndXJhdGlvbi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBMbG1Db25maWd1cmF0aW9uIHtcclxuICBzZXJ2aWNlVXJsOiBzdHJpbmc7XHJcbiAgc3Vic2NyaXB0aW9uVXJsOiBzdHJpbmc7XHJcbiAgc3VwcG9ydEVtYWlsOiBzdHJpbmc7XHJcbiAgaXNXZWJDb21wb25lbnQ6IGJvb2xlYW47XHJcbiAgeEFwaUtleTogc3RyaW5nLFxyXG4gIGFwcElkOiBzdHJpbmdcclxufSJdfQ==
|
|
@@ -2,6 +2,7 @@ import { Inject, Injectable } from '@angular/core';
|
|
|
2
2
|
import { LLM_CONFIGURATION_TOKEN } from '../models/llm-configuration.token';
|
|
3
3
|
import { Subject, takeUntil } from 'rxjs';
|
|
4
4
|
import { NotificationMessageType } from '../../notification-message';
|
|
5
|
+
import { AuthHeadersHelper } from '../../helpers';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/common/http";
|
|
7
8
|
export class LlmService {
|
|
@@ -11,13 +12,15 @@ export class LlmService {
|
|
|
11
12
|
this.llmConfiguration = config;
|
|
12
13
|
}
|
|
13
14
|
summarize(request) {
|
|
15
|
+
const headers = AuthHeadersHelper.getApiV2AuthHeaders(this.llmConfiguration.xApiKey, this.llmConfiguration.appId);
|
|
14
16
|
return this.http
|
|
15
|
-
.post(`${this.llmConfiguration.serviceUrl}/summarize`, request, { responseType: "text" })
|
|
17
|
+
.post(`${this.llmConfiguration.serviceUrl}/summarize`, request, { responseType: "text", headers })
|
|
16
18
|
.pipe(takeUntil(this.cancelSubject));
|
|
17
19
|
}
|
|
18
20
|
rephrase(request) {
|
|
21
|
+
const headers = AuthHeadersHelper.getApiV2AuthHeaders(this.llmConfiguration.xApiKey, this.llmConfiguration.appId);
|
|
19
22
|
return this.http
|
|
20
|
-
.post(`${this.llmConfiguration.serviceUrl}/rewrite`, request, { responseType: "text" })
|
|
23
|
+
.post(`${this.llmConfiguration.serviceUrl}/rewrite`, request, { responseType: "text", headers })
|
|
21
24
|
.pipe(takeUntil(this.cancelSubject));
|
|
22
25
|
}
|
|
23
26
|
cancelRequest() {
|
|
@@ -73,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
73
76
|
type: Inject,
|
|
74
77
|
args: [LLM_CONFIGURATION_TOKEN]
|
|
75
78
|
}] }]; } });
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvbGxtL3NlcnZpY2VzL2xsbS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBRTVFLE9BQU8sRUFBYyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBR3RELE9BQU8sRUFBdUIsdUJBQXVCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMxRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQUtsRCxNQUFNLE9BQU8sVUFBVTtJQUtyQixZQUE2QixJQUFnQixFQUFtQyxNQUF3QjtRQUEzRSxTQUFJLEdBQUosSUFBSSxDQUFZO1FBSnJDLGtCQUFhLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUsxQyxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsTUFBTSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxTQUFTLENBQUMsT0FBWTtRQUNwQixNQUFNLE9BQU8sR0FBRyxpQkFBaUIsQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVsSCxPQUFPLElBQUksQ0FBQyxJQUFJO2FBQ2IsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsWUFBWSxFQUFFLE9BQU8sRUFBRSxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLENBQUM7YUFDakcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRUQsUUFBUSxDQUFDLE9BQW9CO1FBQzNCLE1BQU0sT0FBTyxHQUFHLGlCQUFpQixDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRWxILE9BQU8sSUFBSSxDQUFDLElBQUk7YUFDYixJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxVQUFVLEVBQUUsT0FBTyxFQUFFLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsQ0FBQzthQUMvRixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxhQUFhO1FBQ1gsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUMxQixJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzlCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUNyQyxDQUFDO0lBRUQseUJBQXlCLENBQUMsb0JBQTRCLEVBQUUsUUFBa0I7UUFDeEUsTUFBTSxpQkFBaUIsR0FBRyxFQUFFLENBQUM7UUFDN0IsTUFBTSxlQUFlLEdBQUcsWUFBWSxDQUFDLE9BQU8sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBQ25FLE1BQU0sV0FBVyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUM7UUFDL0IsSUFBSSxVQUFVLEdBQUc7WUFDZixjQUFjLEVBQUUsaUJBQWlCO1lBQ2pDLFVBQVUsRUFBRSxXQUFXO1NBQ3hCLENBQUM7UUFFRixJQUFJLGVBQWUsRUFBRTtZQUNuQixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQzlDLFVBQVUsR0FBRyxTQUFTLENBQUM7WUFFdkIsTUFBTSxZQUFZLEdBQUcsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBRXJELG9FQUFvRTtZQUNwRSxJQUFJLFlBQVksQ0FBQyxPQUFPLEVBQUUsS0FBSyxXQUFXLENBQUMsT0FBTyxFQUFFLElBQUksWUFBWSxDQUFDLFFBQVEsRUFBRSxLQUFLLFdBQVcsQ0FBQyxRQUFRLEVBQUUsSUFBSSxZQUFZLENBQUMsV0FBVyxFQUFFLEtBQUssV0FBVyxDQUFDLFdBQVcsRUFBRSxFQUFFO2dCQUN0SyxpQ0FBaUM7Z0JBQ2pDLFVBQVUsQ0FBQyxjQUFjLEdBQUcsaUJBQWlCLENBQUM7YUFDL0M7WUFFRCxJQUFJLFFBQVEsRUFBRTtnQkFDWixVQUFVLENBQUMsY0FBYyxJQUFJLENBQUMsQ0FBQzthQUNoQztTQUNGO1FBRUQsVUFBVSxDQUFDLFVBQVUsR0FBRyxXQUFXLENBQUM7UUFFcEMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxvQkFBb0IsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7UUFFdkUsT0FBTyxVQUFVLENBQUMsY0FBYyxDQUFDO0lBQ25DLENBQUM7SUFFRCxzQkFBc0I7UUFDcEIsT0FBTztZQUNMLElBQUksRUFBRSx1QkFBdUIsQ0FBQyxLQUFLO1lBQ25DLElBQUksRUFBRSxnQ0FBZ0M7WUFDdEMsU0FBUyxFQUFFLElBQUk7WUFDZixRQUFRLEVBQUUsSUFBSTtZQUNkLGtCQUFrQixFQUFFO2dCQUNsQixlQUFlLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGVBQWU7YUFDdkQ7U0FDRixDQUFDO0lBQ0osQ0FBQzsrR0ExRVUsVUFBVSw0Q0FLa0MsdUJBQXVCO21IQUxuRSxVQUFVLGNBRlQsTUFBTTs7NEZBRVAsVUFBVTtrQkFIdEIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQU1pRCxNQUFNOzJCQUFDLHVCQUF1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBMTE1fQ09ORklHVVJBVElPTl9UT0tFTiB9IGZyb20gJy4uL21vZGVscy9sbG0tY29uZmlndXJhdGlvbi50b2tlbic7XHJcbmltcG9ydCB7IExsbUNvbmZpZ3VyYXRpb24gfSBmcm9tICcuLi9tb2RlbHMvbGxtLWNvbmZpZ3VyYXRpb24ubW9kZWwnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0LCB0YWtlVW50aWwgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgTGxtIH0gZnJvbSAnLi4vbW9kZWxzL2xsbS5tb2RlbCc7XHJcbmltcG9ydCB7IExsbVJlcGhyYXNlIH0gZnJvbSAnLi4vbW9kZWxzL2xsbS1yZXBocmFzZS5tb2RlbCc7XHJcbmltcG9ydCB7IE5vdGlmaWNhdGlvbk1lc3NhZ2UsIE5vdGlmaWNhdGlvbk1lc3NhZ2VUeXBlIH0gZnJvbSAnLi4vLi4vbm90aWZpY2F0aW9uLW1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBBdXRoSGVhZGVyc0hlbHBlciB9IGZyb20gJy4uLy4uL2hlbHBlcnMnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgTGxtU2VydmljZSB7XHJcbiAgcHJpdmF0ZSBjYW5jZWxTdWJqZWN0ID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcclxuXHJcbiAgbGxtQ29uZmlndXJhdGlvbiE6IExsbUNvbmZpZ3VyYXRpb247XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgaHR0cDogSHR0cENsaWVudCwgQEluamVjdChMTE1fQ09ORklHVVJBVElPTl9UT0tFTikgY29uZmlnOiBMbG1Db25maWd1cmF0aW9uKSB7XHJcbiAgICB0aGlzLmxsbUNvbmZpZ3VyYXRpb24gPSBjb25maWc7XHJcbiAgfVxyXG5cclxuICBzdW1tYXJpemUocmVxdWVzdDogTGxtKTogT2JzZXJ2YWJsZTxzdHJpbmc+IHtcclxuICAgIGNvbnN0IGhlYWRlcnMgPSBBdXRoSGVhZGVyc0hlbHBlci5nZXRBcGlWMkF1dGhIZWFkZXJzKHRoaXMubGxtQ29uZmlndXJhdGlvbi54QXBpS2V5LCB0aGlzLmxsbUNvbmZpZ3VyYXRpb24uYXBwSWQpO1xyXG5cclxuICAgIHJldHVybiB0aGlzLmh0dHBcclxuICAgICAgLnBvc3QoYCR7dGhpcy5sbG1Db25maWd1cmF0aW9uLnNlcnZpY2VVcmx9L3N1bW1hcml6ZWAsIHJlcXVlc3QsIHsgcmVzcG9uc2VUeXBlOiBcInRleHRcIiwgaGVhZGVycyB9KVxyXG4gICAgICAucGlwZSh0YWtlVW50aWwodGhpcy5jYW5jZWxTdWJqZWN0KSk7XHJcbiAgfVxyXG5cclxuICByZXBocmFzZShyZXF1ZXN0OiBMbG1SZXBocmFzZSk6IE9ic2VydmFibGU8YW55PiB7XHJcbiAgICBjb25zdCBoZWFkZXJzID0gQXV0aEhlYWRlcnNIZWxwZXIuZ2V0QXBpVjJBdXRoSGVhZGVycyh0aGlzLmxsbUNvbmZpZ3VyYXRpb24ueEFwaUtleSwgdGhpcy5sbG1Db25maWd1cmF0aW9uLmFwcElkKTtcclxuXHJcbiAgICByZXR1cm4gdGhpcy5odHRwXHJcbiAgICAgIC5wb3N0KGAke3RoaXMubGxtQ29uZmlndXJhdGlvbi5zZXJ2aWNlVXJsfS9yZXdyaXRlYCwgcmVxdWVzdCwgeyByZXNwb25zZVR5cGU6IFwidGV4dFwiLCBoZWFkZXJzIH0pXHJcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLmNhbmNlbFN1YmplY3QpKTtcclxuICB9XHJcblxyXG4gIGNhbmNlbFJlcXVlc3QoKTogdm9pZCB7XHJcbiAgICB0aGlzLmNhbmNlbFN1YmplY3QubmV4dCgpO1xyXG4gICAgdGhpcy5jYW5jZWxTdWJqZWN0LmNvbXBsZXRlKCk7XHJcbiAgICB0aGlzLmNhbmNlbFN1YmplY3QgPSBuZXcgU3ViamVjdCgpO1xyXG4gIH1cclxuXHJcbiAgc2V0UXVvdGFMb2NhbFN0b3JhZ2VVc2FnZShxdW90YUxvY2FsU3RvcmFnZUtleTogc3RyaW5nLCBkZWNyZWFzZT86IGJvb2xlYW4pOiBudW1iZXIge1xyXG4gICAgY29uc3QgdHJpYWxSZXF1ZXN0Q291bnQgPSAxNTtcclxuICAgIGNvbnN0IGxvY2FsU3RvcmFnZU9iaiA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKHF1b3RhTG9jYWxTdG9yYWdlS2V5KTtcclxuICAgIGNvbnN0IGN1cnJlbnREYXRlID0gbmV3IERhdGUoKTtcclxuICAgIGxldCB0cmlhbFF1b3RhID0ge1xyXG4gICAgICByZW1haW5pbmdRdW90YTogdHJpYWxSZXF1ZXN0Q291bnQsXHJcbiAgICAgIGxhc3RVc2VkQXQ6IGN1cnJlbnREYXRlXHJcbiAgICB9O1xyXG4gIFxyXG4gICAgaWYgKGxvY2FsU3RvcmFnZU9iaikge1xyXG4gICAgICBjb25zdCBwYXJzZWRPYmogPSBKU09OLnBhcnNlKGxvY2FsU3RvcmFnZU9iaik7XHJcbiAgICAgIHRyaWFsUXVvdGEgPSBwYXJzZWRPYmo7XHJcbiAgXHJcbiAgICAgIGNvbnN0IGxhc3RVc2VkRGF0ZSA9IG5ldyBEYXRlKHRyaWFsUXVvdGEubGFzdFVzZWRBdCk7XHJcbiAgXHJcbiAgICAgIC8vIENoZWNraW5nIGlmIHRoZSBsYXN0IHVzZWQgZGF0ZSBpcyBmcm9tIGEgZGlmZmVyZW50IGRheSB0aGFuIHRvZGF5XHJcbiAgICAgIGlmIChsYXN0VXNlZERhdGUuZ2V0RGF0ZSgpICE9PSBjdXJyZW50RGF0ZS5nZXREYXRlKCkgfHwgbGFzdFVzZWREYXRlLmdldE1vbnRoKCkgIT09IGN1cnJlbnREYXRlLmdldE1vbnRoKCkgfHwgbGFzdFVzZWREYXRlLmdldEZ1bGxZZWFyKCkgIT09IGN1cnJlbnREYXRlLmdldEZ1bGxZZWFyKCkpIHtcclxuICAgICAgICAvLyBSZXNldGluZyBxdW90YSBmb3IgdGhlIG5ldyBkYXlcclxuICAgICAgICB0cmlhbFF1b3RhLnJlbWFpbmluZ1F1b3RhID0gdHJpYWxSZXF1ZXN0Q291bnQ7ICBcclxuICAgICAgfVxyXG4gIFxyXG4gICAgICBpZiAoZGVjcmVhc2UpIHtcclxuICAgICAgICB0cmlhbFF1b3RhLnJlbWFpbmluZ1F1b3RhIC09IDE7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICBcclxuICAgIHRyaWFsUXVvdGEubGFzdFVzZWRBdCA9IGN1cnJlbnREYXRlO1xyXG5cclxuICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKHF1b3RhTG9jYWxTdG9yYWdlS2V5LCBKU09OLnN0cmluZ2lmeSh0cmlhbFF1b3RhKSk7XHJcblxyXG4gICAgcmV0dXJuIHRyaWFsUXVvdGEucmVtYWluaW5nUXVvdGE7XHJcbiAgfVxyXG5cclxuICBnZXRSZWFjaGVkUXVvdGFNZXNzYWdlKCk6IE5vdGlmaWNhdGlvbk1lc3NhZ2Uge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgdHlwZTogTm90aWZpY2F0aW9uTWVzc2FnZVR5cGUuRVJST1IsXHJcbiAgICAgIGJvZHk6ICdMTE0uRVJST1JTLlFVT1RBX0xJTUlUX1JFQUNIRUQnLFxyXG4gICAgICBoaWRlQ2xvc2U6IHRydWUsXHJcbiAgICAgIGhpZGVJY29uOiB0cnVlLFxyXG4gICAgICBsb2NhbGl6YXRpb25QYXJhbXM6IHtcclxuICAgICAgICBzdWJzY3JpcHRpb25Vcmw6IHRoaXMubGxtQ29uZmlndXJhdGlvbi5zdWJzY3JpcHRpb25VcmwsXHJcbiAgICAgIH0sXHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -4268,13 +4268,15 @@ class LlmService {
|
|
|
4268
4268
|
this.llmConfiguration = config;
|
|
4269
4269
|
}
|
|
4270
4270
|
summarize(request) {
|
|
4271
|
+
const headers = AuthHeadersHelper.getApiV2AuthHeaders(this.llmConfiguration.xApiKey, this.llmConfiguration.appId);
|
|
4271
4272
|
return this.http
|
|
4272
|
-
.post(`${this.llmConfiguration.serviceUrl}/summarize`, request, { responseType: "text" })
|
|
4273
|
+
.post(`${this.llmConfiguration.serviceUrl}/summarize`, request, { responseType: "text", headers })
|
|
4273
4274
|
.pipe(takeUntil(this.cancelSubject));
|
|
4274
4275
|
}
|
|
4275
4276
|
rephrase(request) {
|
|
4277
|
+
const headers = AuthHeadersHelper.getApiV2AuthHeaders(this.llmConfiguration.xApiKey, this.llmConfiguration.appId);
|
|
4276
4278
|
return this.http
|
|
4277
|
-
.post(`${this.llmConfiguration.serviceUrl}/rewrite`, request, { responseType: "text" })
|
|
4279
|
+
.post(`${this.llmConfiguration.serviceUrl}/rewrite`, request, { responseType: "text", headers })
|
|
4278
4280
|
.pipe(takeUntil(this.cancelSubject));
|
|
4279
4281
|
}
|
|
4280
4282
|
cancelRequest() {
|
|
@@ -4425,6 +4427,10 @@ class RephraseTranslationComponent {
|
|
|
4425
4427
|
this.llmService.cancelRequest();
|
|
4426
4428
|
}
|
|
4427
4429
|
refreshQuota(decrease) {
|
|
4430
|
+
if (this.llmService.llmConfiguration.isWebComponent) {
|
|
4431
|
+
this.rephraseQuotaLeft = this.llmService.setQuotaLocalStorageUsage(this.rephraseQuotaLocalStorageKey, decrease);
|
|
4432
|
+
return;
|
|
4433
|
+
}
|
|
4428
4434
|
this.quotaService.getQuotaUsage().subscribe({
|
|
4429
4435
|
next: (response) => {
|
|
4430
4436
|
const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_CHARACTER_COUNT);
|
|
@@ -4485,6 +4491,10 @@ class CreateSummaryComponent {
|
|
|
4485
4491
|
this.llmService.cancelRequest();
|
|
4486
4492
|
}
|
|
4487
4493
|
refreshQuota(decrease) {
|
|
4494
|
+
if (this.llmService.llmConfiguration.isWebComponent) {
|
|
4495
|
+
this.summaryQuotaLeft = this.llmService.setQuotaLocalStorageUsage(this.summaryQuotaLocalStorageKey, decrease);
|
|
4496
|
+
return;
|
|
4497
|
+
}
|
|
4488
4498
|
this.quotaService.getQuotaUsage().subscribe({
|
|
4489
4499
|
next: (response) => {
|
|
4490
4500
|
const quota = response.usage.find((item) => item.quotaType === QuotaType.LLM_REQUESTS);
|