@tilde-nlp/ngx-common 4.1.38 → 4.1.40

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.
@@ -23,9 +23,6 @@ export class LLMTextareaWithActionsComponent {
23
23
  get isDisabled() {
24
24
  return this.isLoading || !this.initialText || this.quotaLeft < 1;
25
25
  }
26
- get showMissingQuotaMessage() {
27
- return !this.quotaLeft && !this.missingQuotaMessageClosed && this.isQuotaLoaded;
28
- }
29
26
  constructor(llmService, llmHelperService, data) {
30
27
  this.llmService = llmService;
31
28
  this.llmHelperService = llmHelperService;
@@ -37,7 +34,6 @@ export class LLMTextareaWithActionsComponent {
37
34
  this.llmActions = LLMActions;
38
35
  this.writingStyles = Object.values(LLMWritingStyle);
39
36
  this.messages = [];
40
- this.missingQuotaMessageClosed = false;
41
37
  }
42
38
  ngOnInit() {
43
39
  this.llmActionType = this.data.action;
@@ -118,13 +114,14 @@ export class LLMTextareaWithActionsComponent {
118
114
  refreshQuota(decrease) {
119
115
  this.llmHelperService.getRemainingQuota(decrease).subscribe((remainingQuota) => {
120
116
  this.quotaLeft = remainingQuota;
121
- this.isQuotaLoaded = true;
122
117
  this.setQuotaMessage();
123
118
  });
124
119
  }
125
120
  setQuotaMessage() {
126
121
  if (this.quotaLeft <= this.llmHelperService.trialRequestCount) {
127
122
  this.remainingQuotaMessageVisible = true;
123
+ }
124
+ if (this.quotaLeft < 1) {
128
125
  this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();
129
126
  this.messages.push(this.reachedQuotaMessage);
130
127
  }
@@ -178,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
178
175
  type: Inject,
179
176
  args: [MAT_DIALOG_DATA]
180
177
  }] }]; } });
181
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"llm-textarea-with-actions.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/llm/components/llm-textarea-with-actions/llm-textarea-with-actions.component.ts","../../../../../../../projects/ngx-common/src/lib/llm/components/llm-textarea-with-actions/llm-textarea-with-actions.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 { MatSelectChange } from '@angular/material/select';\r\nimport { Subscription, finalize } from 'rxjs';\r\nimport { LLMActions } from '../../models/llm-actions.enum';\r\nimport { LLMData } from '../../models/llm-data.model';\r\nimport { LLMWritingStyle } from '../../models/llm-writing-style.enum';\r\nimport { LLMHelperService } from '../../services/llm-helper.service';\r\nimport { LLMService } from '../../services/llm.service';\r\nimport { NotificationMessage } from '../../../notification-message';\r\nimport { PlausibleHelper } from '../../../plausible';\r\nimport { ERROR_CODES } from '../../../constants';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\n\r\n@Component({\r\n  selector: 'lib-llm-textarea-with-actions',\r\n  templateUrl: './llm-textarea-with-actions.component.html',\r\n  styleUrls: ['./llm-textarea-with-actions.component.scss']\r\n})\r\nexport class LLMTextareaWithActionsComponent implements OnInit {\r\n  isLoading!: boolean;\r\n  isSummarized!: boolean;\r\n  isEdited!: boolean;\r\n  isQuotaLoaded!: boolean;\r\n  remainingQuotaMessageVisible!: boolean;\r\n  quotaLeft!: number;\r\n  maxCharLength!: number;\r\n  subscriptionUrl!: string;\r\n  previousWritingStyle!: LLMWritingStyle;\r\n  selectedWritingStyle = LLMWritingStyle.GENERAL;\r\n\r\n  reachedQuotaMessage!: NotificationMessage;\r\n  exceededLimitMessage!: NotificationMessage;\r\n  requestTimeoutMessage!: NotificationMessage;\r\n  defaultErrorMessage!: NotificationMessage;\r\n\r\n  subscription!: Subscription;\r\n\r\n  initialText!: string;\r\n  editedText = '';\r\n  manuallyEditedText = '';\r\n\r\n  localizationKey!: string;\r\n\r\n  llmActionType!: LLMActions;\r\n\r\n  private savedRephrasings: { style: LLMWritingStyle, text: string }[] = [];\r\n\r\n  readonly llmActions = LLMActions;\r\n  readonly writingStyles = Object.values(LLMWritingStyle);\r\n\r\n  readonly messages: NotificationMessage[] = [];\r\n\r\n  missingQuotaMessageClosed = false;\r\n\r\n  get isDisabled() {\r\n    return this.isLoading || !this.initialText || this.quotaLeft < 1;\r\n  }\r\n\r\n  get showMissingQuotaMessage() {\r\n    return !this.quotaLeft && !this.missingQuotaMessageClosed && this.isQuotaLoaded;\r\n  }\r\n\r\n  constructor(\r\n    private readonly llmService: LLMService,\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.llmActionType = this.data.action;\r\n    this.localizationKey = `LLM.${this.llmActionType}_MODAL.`\r\n    this.initialText = this.data.text;\r\n    this.subscriptionUrl = this.llmService.llmConfiguration.subscriptionUrl;\r\n    this.maxCharLength = this.llmService.llmConfiguration.maxCharLength;\r\n\r\n    this.refreshQuota();\r\n  }\r\n\r\n  closeMessage(msg: NotificationMessage): void {\r\n    const index = this.messages?.findIndex((message) => JSON.stringify(message) === JSON.stringify(msg));\r\n    \r\n    if (index || index === 0) {\r\n      this.messages.splice(index, 1);\r\n    }\r\n  }\r\n\r\n  checkRephrasedTextSaves(event: MatSelectChange): void {\r\n    if (event.value !== this.selectedWritingStyle) {\r\n      this.previousWritingStyle = this.selectedWritingStyle;\r\n      this.selectedWritingStyle = event.value;\r\n    }\r\n\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      previousWritingStyleSave.text = this.editedText !== '' ? this.editedText : this.initialText;\r\n    } else {\r\n      this.savedRephrasings.push({ style: this.previousWritingStyle, text: this.editedText !== '' ? this.editedText : this.initialText });\r\n    }\r\n    \r\n    this.editedText = selectedWritingStyleSave?.text ?? this.initialText;\r\n    this.manuallyEditedText = '';\r\n\r\n    this.checkTextLimit();\r\n  }\r\n\r\n  getEditedText(): void {\r\n    this.isLoading = true;\r\n\r\n    if (this.llmActionType === LLMActions.REPHRASE) {\r\n      this.writingStylePlausibleEvent();\r\n    } else {\r\n      this.summaryPlausibleEvent();\r\n    }\r\n\r\n    this.subscription = this.getRequest();\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.editedText = '';\r\n\r\n    this.checkTextLimit();\r\n  }\r\n\r\n  copyPlausibleEvent(): void {\r\n    PlausibleHelper.customEvent(this.llmActionType.toLowerCase(), { action: 'copy' });\r\n  }\r\n  \r\n  dislikePlausibleEvent(): void {\r\n    PlausibleHelper.customEvent(this.llmActionType.toLowerCase(), { action: 'dislike' });\r\n  }\r\n\r\n  private checkTextLimit(): void {\r\n    const limit = this.maxCharLength;\r\n    const texts = [this.initialText, this.manuallyEditedText, this.editedText];\r\n    const longestText = this.editedText && !this.manuallyEditedText ? this.editedText : texts.reduce((a, b) => a.length > b.length ? a : b);\r\n  \r\n    if (longestText.length > limit) {\r\n      if (this.exceededLimitMessage) {\r\n        this.closeMessage(this.exceededLimitMessage);\r\n      }\r\n\r\n      this.exceededLimitMessage = this.llmHelperService.getExceededLimitMessage(longestText.length);\r\n      this.messages.push(this.exceededLimitMessage)\r\n      return;\r\n    }  \r\n\r\n    this.closeMessage(this.exceededLimitMessage);\r\n  }  \r\n\r\n  private writingStylePlausibleEvent(): void {\r\n    PlausibleHelper.customEvent(this.llmActionType.toLowerCase(), { writingStyle: this.selectedWritingStyle });\r\n  }\r\n\r\n  private summaryPlausibleEvent(): void {\r\n    PlausibleHelper.customEvent(this.llmActionType.toLowerCase(), { action: 'summary' });\r\n  }\r\n\r\n  private refreshQuota(decrease?: boolean): void {\r\n    this.llmHelperService.getRemainingQuota(decrease).subscribe((remainingQuota) => {\r\n      this.quotaLeft = remainingQuota;\r\n      this.isQuotaLoaded = true;\r\n      this.setQuotaMessage();\r\n    })\r\n  }\r\n\r\n  private setQuotaMessage(): void {\r\n    if (this.quotaLeft <= this.llmHelperService.trialRequestCount) {\r\n      this.remainingQuotaMessageVisible = true;\r\n      this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();\r\n      this.messages.push(this.reachedQuotaMessage);\r\n    }\r\n  }\r\n\r\n  private getRequest(): Subscription {\r\n    let text =\r\n      this.manuallyEditedText !== ''\r\n        ? this.manuallyEditedText\r\n        : this.initialText;\r\n\r\n    if (text.length > this.maxCharLength) {\r\n      text = text.substring(0, this.maxCharLength);\r\n    }\r\n\r\n    const method =\r\n      this.llmActionType === LLMActions.REPHRASE\r\n        ? this.llmService.rephrase({ text: text, style: this.selectedWritingStyle })\r\n        : this.llmService.summarize({ text: text, language: this.data.language });\r\n\r\n    return method\r\n      .pipe(finalize(() => (this.isLoading = false)))\r\n      .subscribe(this.getRequestCallback());\r\n  }\r\n\r\n  private getRequestCallback() {\r\n    return {\r\n      next: (response: string) => {\r\n        if (this.llmActionType === this.llmActions.SUMMARY) {\r\n          this.isSummarized = true;\r\n        }\r\n        \r\n        this.editedText = response;\r\n        this.manuallyEditedText = '';\r\n        this.defaultErrorMessage = this.llmHelperService.getDefaultErrorMessage();\r\n        this.closeMessage(this.defaultErrorMessage);\r\n        this.closeMessage(this.requestTimeoutMessage);\r\n        this.isEdited = true;\r\n        this.refreshQuota(true);\r\n        this.checkTextLimit();\r\n      },\r\n      error: (error: HttpErrorResponse) => {\r\n        if (error.status === ERROR_CODES.TIMEOUT) {\r\n          this.requestTimeoutMessage = this.llmHelperService.getRequestTimeoutMessage(this.llmActionType);\r\n          this.messages.push(this.requestTimeoutMessage);\r\n          return;\r\n        }\r\n\r\n        this.messages.push(this.defaultErrorMessage);\r\n      }\r\n    }\r\n  }\r\n}\r\n","<h1 mat-dialog-title>{{ localizationKey + \"TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n  <p>{{ localizationKey + \"DESCRIPTION\" | translate }}</p>\r\n\r\n  <lib-tld-notification-message *ngFor=\"let message of messages\" [message]=\"message\" (closeClicked)=\"closeMessage(message)\"></lib-tld-notification-message>\r\n\r\n  <ng-container *ngIf=\"llmActionType === llmActions.REPHRASE\">\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 [disabled]=\"isLoading\" (selectionChange)=\"checkRephrasedTextSaves($event)\" [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  </ng-container>\r\n\r\n  <lib-llm-textarea [text]=\"editedText !== '' ? editedText : initialText\" [disabled]=\"isLoading || !quotaLeft\" [actionButtonsDisabled]=\"!isEdited\" (textEditEvent)=\"textEditEvent($event)\" (copyEvent)=\"copyPlausibleEvent()\" (dislikeEvent)=\"dislikePlausibleEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-actions-wrapper\" mat-dialog-actions>\r\n  <div *ngIf=\"remainingQuotaMessageVisible\" [innerHTML]=\"localizationKey + 'LIMIT' | translate: { limit: quotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n  <div [class.w-full]=\"!remainingQuotaMessageVisible\" class=\"llm-actions\">\r\n    <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n      {{ localizationKey + \"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        {{ localizationKey + \"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)=\"getEditedText()\"\r\n      [disabled]=\"isDisabled\"\r\n    >\r\n      <span *ngIf=\"llmActionType === llmActions.SUMMARY; else rephraseAction\">\r\n        {{\r\n          (!isSummarized\r\n            ? \"LLM.SUMMARY_MODAL.ACTION\"\r\n            : \"LLM.SUMMARY_MODAL.REGENERATE\"\r\n          ) | translate\r\n        }}\r\n      </span>\r\n\r\n      <ng-template #rephraseAction>\r\n        {{ localizationKey + \"ACTION\" | translate }}\r\n      </ng-template>\r\n      <mat-spinner *ngIf=\"isLoading\" [diameter]=\"20\" color=\"accent\"></mat-spinner>\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"llm-textarea-with-actions.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/llm/components/llm-textarea-with-actions/llm-textarea-with-actions.component.ts","../../../../../../../projects/ngx-common/src/lib/llm/components/llm-textarea-with-actions/llm-textarea-with-actions.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 { MatSelectChange } from '@angular/material/select';\r\nimport { Subscription, finalize } from 'rxjs';\r\nimport { LLMActions } from '../../models/llm-actions.enum';\r\nimport { LLMData } from '../../models/llm-data.model';\r\nimport { LLMWritingStyle } from '../../models/llm-writing-style.enum';\r\nimport { LLMHelperService } from '../../services/llm-helper.service';\r\nimport { LLMService } from '../../services/llm.service';\r\nimport { NotificationMessage } from '../../../notification-message';\r\nimport { PlausibleHelper } from '../../../plausible';\r\nimport { ERROR_CODES } from '../../../constants';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\n\r\n@Component({\r\n  selector: 'lib-llm-textarea-with-actions',\r\n  templateUrl: './llm-textarea-with-actions.component.html',\r\n  styleUrls: ['./llm-textarea-with-actions.component.scss']\r\n})\r\nexport class LLMTextareaWithActionsComponent implements OnInit {\r\n  isLoading!: boolean;\r\n  isSummarized!: boolean;\r\n  isEdited!: boolean;\r\n  remainingQuotaMessageVisible!: boolean;\r\n  quotaLeft!: number;\r\n  maxCharLength!: number;\r\n  subscriptionUrl!: string;\r\n  previousWritingStyle!: LLMWritingStyle;\r\n  selectedWritingStyle = LLMWritingStyle.GENERAL;\r\n\r\n  reachedQuotaMessage!: NotificationMessage;\r\n  exceededLimitMessage!: NotificationMessage;\r\n  requestTimeoutMessage!: NotificationMessage;\r\n  defaultErrorMessage!: NotificationMessage;\r\n\r\n  subscription!: Subscription;\r\n\r\n  initialText!: string;\r\n  editedText = '';\r\n  manuallyEditedText = '';\r\n\r\n  localizationKey!: string;\r\n\r\n  llmActionType!: LLMActions;\r\n\r\n  private savedRephrasings: { style: LLMWritingStyle, text: string }[] = [];\r\n\r\n  readonly llmActions = LLMActions;\r\n  readonly writingStyles = Object.values(LLMWritingStyle);\r\n\r\n  readonly messages: NotificationMessage[] = [];\r\n\r\n  get isDisabled() {\r\n    return this.isLoading || !this.initialText || this.quotaLeft < 1;\r\n  }\r\n\r\n  constructor(\r\n    private readonly llmService: LLMService,\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.llmActionType = this.data.action;\r\n    this.localizationKey = `LLM.${this.llmActionType}_MODAL.`\r\n    this.initialText = this.data.text;\r\n    this.subscriptionUrl = this.llmService.llmConfiguration.subscriptionUrl;\r\n    this.maxCharLength = this.llmService.llmConfiguration.maxCharLength;\r\n\r\n    this.refreshQuota();\r\n  }\r\n\r\n  closeMessage(msg: NotificationMessage): void {\r\n    const index = this.messages?.findIndex((message) => JSON.stringify(message) === JSON.stringify(msg));\r\n    \r\n    if (index || index === 0) {\r\n      this.messages.splice(index, 1);\r\n    }\r\n  }\r\n\r\n  checkRephrasedTextSaves(event: MatSelectChange): void {\r\n    if (event.value !== this.selectedWritingStyle) {\r\n      this.previousWritingStyle = this.selectedWritingStyle;\r\n      this.selectedWritingStyle = event.value;\r\n    }\r\n\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      previousWritingStyleSave.text = this.editedText !== '' ? this.editedText : this.initialText;\r\n    } else {\r\n      this.savedRephrasings.push({ style: this.previousWritingStyle, text: this.editedText !== '' ? this.editedText : this.initialText });\r\n    }\r\n    \r\n    this.editedText = selectedWritingStyleSave?.text ?? this.initialText;\r\n    this.manuallyEditedText = '';\r\n\r\n    this.checkTextLimit();\r\n  }\r\n\r\n  getEditedText(): void {\r\n    this.isLoading = true;\r\n\r\n    if (this.llmActionType === LLMActions.REPHRASE) {\r\n      this.writingStylePlausibleEvent();\r\n    } else {\r\n      this.summaryPlausibleEvent();\r\n    }\r\n\r\n    this.subscription = this.getRequest();\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.editedText = '';\r\n\r\n    this.checkTextLimit();\r\n  }\r\n\r\n  copyPlausibleEvent(): void {\r\n    PlausibleHelper.customEvent(this.llmActionType.toLowerCase(), { action: 'copy' });\r\n  }\r\n  \r\n  dislikePlausibleEvent(): void {\r\n    PlausibleHelper.customEvent(this.llmActionType.toLowerCase(), { action: 'dislike' });\r\n  }\r\n\r\n  private checkTextLimit(): void {\r\n    const limit = this.maxCharLength;\r\n    const texts = [this.initialText, this.manuallyEditedText, this.editedText];\r\n    const longestText = this.editedText && !this.manuallyEditedText ? this.editedText : texts.reduce((a, b) => a.length > b.length ? a : b);\r\n  \r\n    if (longestText.length > limit) {\r\n      if (this.exceededLimitMessage) {\r\n        this.closeMessage(this.exceededLimitMessage);\r\n      }\r\n\r\n      this.exceededLimitMessage = this.llmHelperService.getExceededLimitMessage(longestText.length);\r\n      this.messages.push(this.exceededLimitMessage)\r\n      return;\r\n    }  \r\n\r\n    this.closeMessage(this.exceededLimitMessage);\r\n  }  \r\n\r\n  private writingStylePlausibleEvent(): void {\r\n    PlausibleHelper.customEvent(this.llmActionType.toLowerCase(), { writingStyle: this.selectedWritingStyle });\r\n  }\r\n\r\n  private summaryPlausibleEvent(): void {\r\n    PlausibleHelper.customEvent(this.llmActionType.toLowerCase(), { action: 'summary' });\r\n  }\r\n\r\n  private refreshQuota(decrease?: boolean): void {\r\n    this.llmHelperService.getRemainingQuota(decrease).subscribe((remainingQuota) => {\r\n      this.quotaLeft = remainingQuota;\r\n      this.setQuotaMessage();\r\n    })\r\n  }\r\n\r\n  private setQuotaMessage(): void {\r\n    if (this.quotaLeft <= this.llmHelperService.trialRequestCount) {\r\n      this.remainingQuotaMessageVisible = true;\r\n    }\r\n\r\n    if (this.quotaLeft < 1) {\r\n      this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();\r\n      this.messages.push(this.reachedQuotaMessage);\r\n    }\r\n  }\r\n\r\n  private getRequest(): Subscription {\r\n    let text =\r\n      this.manuallyEditedText !== ''\r\n        ? this.manuallyEditedText\r\n        : this.initialText;\r\n\r\n    if (text.length > this.maxCharLength) {\r\n      text = text.substring(0, this.maxCharLength);\r\n    }\r\n\r\n    const method =\r\n      this.llmActionType === LLMActions.REPHRASE\r\n        ? this.llmService.rephrase({ text: text, style: this.selectedWritingStyle })\r\n        : this.llmService.summarize({ text: text, language: this.data.language });\r\n\r\n    return method\r\n      .pipe(finalize(() => (this.isLoading = false)))\r\n      .subscribe(this.getRequestCallback());\r\n  }\r\n\r\n  private getRequestCallback() {\r\n    return {\r\n      next: (response: string) => {\r\n        if (this.llmActionType === this.llmActions.SUMMARY) {\r\n          this.isSummarized = true;\r\n        }\r\n        \r\n        this.editedText = response;\r\n        this.manuallyEditedText = '';\r\n        this.defaultErrorMessage = this.llmHelperService.getDefaultErrorMessage();\r\n        this.closeMessage(this.defaultErrorMessage);\r\n        this.closeMessage(this.requestTimeoutMessage);\r\n        this.isEdited = true;\r\n        this.refreshQuota(true);\r\n        this.checkTextLimit();\r\n      },\r\n      error: (error: HttpErrorResponse) => {\r\n        if (error.status === ERROR_CODES.TIMEOUT) {\r\n          this.requestTimeoutMessage = this.llmHelperService.getRequestTimeoutMessage(this.llmActionType);\r\n          this.messages.push(this.requestTimeoutMessage);\r\n          return;\r\n        }\r\n\r\n        this.messages.push(this.defaultErrorMessage);\r\n      }\r\n    }\r\n  }\r\n}\r\n","<h1 mat-dialog-title>{{ localizationKey + \"TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n  <p>{{ localizationKey + \"DESCRIPTION\" | translate }}</p>\r\n\r\n  <lib-tld-notification-message *ngFor=\"let message of messages\" [message]=\"message\" (closeClicked)=\"closeMessage(message)\"></lib-tld-notification-message>\r\n\r\n  <ng-container *ngIf=\"llmActionType === llmActions.REPHRASE\">\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 [disabled]=\"isLoading\" (selectionChange)=\"checkRephrasedTextSaves($event)\" [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  </ng-container>\r\n\r\n  <lib-llm-textarea [text]=\"editedText !== '' ? editedText : initialText\" [disabled]=\"isLoading || !quotaLeft\" [actionButtonsDisabled]=\"!isEdited\" (textEditEvent)=\"textEditEvent($event)\" (copyEvent)=\"copyPlausibleEvent()\" (dislikeEvent)=\"dislikePlausibleEvent()\"></lib-llm-textarea>\r\n</div>\r\n<div class=\"llm-actions-wrapper\" mat-dialog-actions>\r\n  <div *ngIf=\"remainingQuotaMessageVisible\" [innerHTML]=\"localizationKey + 'LIMIT' | translate: { limit: quotaLeft, subscriptionUrl: subscriptionUrl }\"></div>\r\n\r\n  <div [class.w-full]=\"!remainingQuotaMessageVisible\" class=\"llm-actions\">\r\n    <button *ngIf=\"isLoading; else closeButton\" mat-button color=\"accent\" (click)=\"cancel()\">\r\n      {{ localizationKey + \"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        {{ localizationKey + \"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)=\"getEditedText()\"\r\n      [disabled]=\"isDisabled\"\r\n    >\r\n      <span *ngIf=\"llmActionType === llmActions.SUMMARY; else rephraseAction\">\r\n        {{\r\n          (!isSummarized\r\n            ? \"LLM.SUMMARY_MODAL.ACTION\"\r\n            : \"LLM.SUMMARY_MODAL.REGENERATE\"\r\n          ) | translate\r\n        }}\r\n      </span>\r\n\r\n      <ng-template #rephraseAction>\r\n        {{ localizationKey + \"ACTION\" | translate }}\r\n      </ng-template>\r\n      <mat-spinner *ngIf=\"isLoading\" [diameter]=\"20\" color=\"accent\"></mat-spinner>\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
@@ -28,7 +28,8 @@ export class LLMComponent {
28
28
  openLLMModal(action) {
29
29
  this.dialog.open(LLMTextareaWithActionsComponent, {
30
30
  panelClass: 'responsive-dialog',
31
- maxWidth: '850px',
31
+ maxWidth: '800px',
32
+ width: '100%',
32
33
  data: {
33
34
  text: this.text,
34
35
  language: this.language,
@@ -51,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
51
52
  }], rephrasableLanguagesCodeList: [{
52
53
  type: Input
53
54
  }] } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUd2RCxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSw0RUFBNEUsQ0FBQztBQUM3SCxPQUFPLEtBQUssS0FBSyxNQUFNLFNBQVMsQ0FBQzs7Ozs7Ozs7O0FBT2pDLE1BQU0sT0FBTyxZQUFZO0lBUXZCLElBQUksa0JBQWtCO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsR0FBRyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxJQUFJLDJCQUEyQjtRQUM3QixPQUFPLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyw0QkFBNEIsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUN0SCxDQUFDO0lBRUQsWUFDUyxNQUFpQixFQUNQLFdBQXdCLEVBQ3hCLGVBQXlDO1FBRm5ELFdBQU0sR0FBTixNQUFNLENBQVc7UUFDUCxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUN4QixvQkFBZSxHQUFmLGVBQWUsQ0FBMEI7UUFmbkQsaUNBQTRCLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUV0QyxjQUFTLEdBQUcsVUFBVSxDQUFDO1FBZTlCLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRCxZQUFZLENBQUMsTUFBa0I7UUFDN0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsK0JBQStCLEVBQUU7WUFDaEQsVUFBVSxFQUFFLG1CQUFtQjtZQUMvQixRQUFRLEVBQUUsT0FBTztZQUNqQixJQUFJLEVBQUU7Z0JBQ0osSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO2dCQUNmLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTtnQkFDdkIsTUFBTSxFQUFFLE1BQU07YUFDZjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7K0dBbENVLFlBQVk7bUdBQVosWUFBWSwrTENaekIsNDZCQThCQTs7NEZEbEJhLFlBQVk7a0JBTHhCLFNBQVM7K0JBQ0UsU0FBUztpS0FLVixJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLDRCQUE0QjtzQkFBcEMsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTExNQWN0aW9ucyB9IGZyb20gJy4vbW9kZWxzL2xsbS1hY3Rpb25zLmVudW0nO1xyXG5pbXBvcnQgeyBNYXREaWFsb2cgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyBJY29uU2VydmljZSwgTGFuZ3VhZ2VUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMnO1xyXG5pbXBvcnQgeyBMTE1UZXh0YXJlYVdpdGhBY3Rpb25zQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2xsbS10ZXh0YXJlYS13aXRoLWFjdGlvbnMvbGxtLXRleHRhcmVhLXdpdGgtYWN0aW9ucy5jb21wb25lbnQnO1xyXG5pbXBvcnQgKiBhcyBpY29ucyBmcm9tICcuL2ljb25zJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLWxsbScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2xsbS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbGxtLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMTE1Db21wb25lbnQge1xyXG4gIEBJbnB1dCgpIHRleHQhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgbGFuZ3VhZ2UhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgaXNNZW51RGlzYWJsZWQhOiBib29sZWFuO1xyXG4gIEBJbnB1dCgpIHJlcGhyYXNhYmxlTGFuZ3VhZ2VzQ29kZUxpc3QgPSBbJ2VuJ107XHJcblxyXG4gIHJlYWRvbmx5IGxsbUFjdGlvbiA9IExMTUFjdGlvbnM7XHJcblxyXG4gIGdldCBpc1RleHRTdW1tYXJpemFibGUoKSB7XHJcbiAgICByZXR1cm4gdGhpcy50ZXh0Lmxlbmd0aCA+IDEwMDtcclxuICB9XHJcblxyXG4gIGdldCBpc1RhcmdldExhbmd1YWdlUmVwaHJhc2FibGUoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5yZXBocmFzYWJsZUxhbmd1YWdlc0NvZGVMaXN0LmluY2x1ZGVzKHRoaXMubGFuZ3VhZ2VTZXJ2aWNlLnJlbW92ZVJlZ2lvbkZyb21MYW5ndWFnZUNvZGUodGhpcy5sYW5ndWFnZSkpO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgZGlhbG9nOiBNYXREaWFsb2csIFxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBpY29uU2VydmljZTogSWNvblNlcnZpY2UsIFxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBsYW5ndWFnZVNlcnZpY2U6IExhbmd1YWdlVHJhbnNsYXRlU2VydmljZVxyXG4gICkge1xyXG4gICAgdGhpcy5pY29uU2VydmljZS5yZWdpc3Rlckljb25zKGljb25zKTtcclxuICB9XHJcblxyXG4gIG9wZW5MTE1Nb2RhbChhY3Rpb246IExMTUFjdGlvbnMpOiB2b2lkIHtcclxuICAgIHRoaXMuZGlhbG9nLm9wZW4oTExNVGV4dGFyZWFXaXRoQWN0aW9uc0NvbXBvbmVudCwge1xyXG4gICAgICBwYW5lbENsYXNzOiAncmVzcG9uc2l2ZS1kaWFsb2cnLFxyXG4gICAgICBtYXhXaWR0aDogJzg1MHB4JyxcclxuICAgICAgZGF0YToge1xyXG4gICAgICAgIHRleHQ6IHRoaXMudGV4dCxcclxuICAgICAgICBsYW5ndWFnZTogdGhpcy5sYW5ndWFnZSxcclxuICAgICAgICBhY3Rpb246IGFjdGlvblxyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICB9XHJcbn1cclxuIiwiPGJ1dHRvblxyXG4gIFtkaXNhYmxlZF09XCJpc01lbnVEaXNhYmxlZFwiXHJcbiAgW21hdFRvb2x0aXBdPVwiJ0xMTS5NRU5VX1RPT0xUSVAnIHwgdHJhbnNsYXRlXCJcclxuICBtYXQtaWNvbi1idXR0b25cclxuICBbbWF0TWVudVRyaWdnZXJGb3JdPVwibWVudVwiXHJcbj5cclxuICA8bWF0LWljb24gc3ZnSWNvbj1cImxsbV9tZW51XCI+PC9tYXQtaWNvbj5cclxuPC9idXR0b24+XHJcblxyXG48bWF0LW1lbnUgI21lbnU9XCJtYXRNZW51XCI+XHJcbiAgPGRpdiBbbWF0VG9vbHRpcF09XCIhaXNUZXh0U3VtbWFyaXphYmxlID8gKCdMTE0uTUVOVV9TVU1NQVJZX0RJU0FCTEVEX1RPT0xUSVAnIHwgdHJhbnNsYXRlKSA6ICcnXCI+XHJcbiAgICA8YnV0dG9uXHJcbiAgICAgIG1hdC1tZW51LWl0ZW1cclxuICAgICAgW2Rpc2FibGVkXT1cIiFpc1RleHRTdW1tYXJpemFibGVcIlxyXG4gICAgICAoY2xpY2spPVwib3BlbkxMTU1vZGFsKGxsbUFjdGlvbi5TVU1NQVJZKVwiXHJcbiAgICA+XHJcbiAgICAgIHt7IFwiTExNLlNVTU1BUllcIiB8IHRyYW5zbGF0ZSB9fVxyXG4gICAgPC9idXR0b24+XHJcbiAgPC9kaXY+XHJcblxyXG4gIDxkaXYgW21hdFRvb2x0aXBdPVwiIWlzVGFyZ2V0TGFuZ3VhZ2VSZXBocmFzYWJsZSA/ICgnTExNLk1FTlVfUkVQSFJBU0VfRElTQUJMRURfVE9PTFRJUCcgfCB0cmFuc2xhdGUpIDogJydcIj5cclxuICAgIDxidXR0b25cclxuICAgICAgbWF0LW1lbnUtaXRlbVxyXG4gICAgICBbZGlzYWJsZWRdPVwiIWlzVGFyZ2V0TGFuZ3VhZ2VSZXBocmFzYWJsZVwiXHJcbiAgICAgIChjbGljayk9XCJvcGVuTExNTW9kYWwobGxtQWN0aW9uLlJFUEhSQVNFKVwiXHJcbiAgICA+XHJcbiAgICAgIHt7IFwiTExNLlJFUEhSQVNFXCIgfCB0cmFuc2xhdGUgfX1cclxuICAgIDwvYnV0dG9uPlxyXG4gIDwvZGl2PlxyXG48L21hdC1tZW51PlxyXG4iXX0=
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGxtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9sbG0vbGxtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUd2RCxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSw0RUFBNEUsQ0FBQztBQUM3SCxPQUFPLEtBQUssS0FBSyxNQUFNLFNBQVMsQ0FBQzs7Ozs7Ozs7O0FBT2pDLE1BQU0sT0FBTyxZQUFZO0lBUXZCLElBQUksa0JBQWtCO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsR0FBRyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxJQUFJLDJCQUEyQjtRQUM3QixPQUFPLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyw0QkFBNEIsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUN0SCxDQUFDO0lBRUQsWUFDUyxNQUFpQixFQUNQLFdBQXdCLEVBQ3hCLGVBQXlDO1FBRm5ELFdBQU0sR0FBTixNQUFNLENBQVc7UUFDUCxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUN4QixvQkFBZSxHQUFmLGVBQWUsQ0FBMEI7UUFmbkQsaUNBQTRCLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUV0QyxjQUFTLEdBQUcsVUFBVSxDQUFDO1FBZTlCLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRCxZQUFZLENBQUMsTUFBa0I7UUFDN0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsK0JBQStCLEVBQUU7WUFDaEQsVUFBVSxFQUFFLG1CQUFtQjtZQUMvQixRQUFRLEVBQUUsT0FBTztZQUNqQixLQUFLLEVBQUUsTUFBTTtZQUNiLElBQUksRUFBRTtnQkFDSixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7Z0JBQ2YsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO2dCQUN2QixNQUFNLEVBQUUsTUFBTTthQUNmO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzsrR0FuQ1UsWUFBWTttR0FBWixZQUFZLCtMQ1p6Qiw0NkJBOEJBOzs0RkRsQmEsWUFBWTtrQkFMeEIsU0FBUzsrQkFDRSxTQUFTO2lLQUtWLElBQUk7c0JBQVosS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csNEJBQTRCO3NCQUFwQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBMTE1BY3Rpb25zIH0gZnJvbSAnLi9tb2RlbHMvbGxtLWFjdGlvbnMuZW51bSc7XHJcbmltcG9ydCB7IE1hdERpYWxvZyB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IEljb25TZXJ2aWNlLCBMYW5ndWFnZVRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IExMTVRleHRhcmVhV2l0aEFjdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvbGxtLXRleHRhcmVhLXdpdGgtYWN0aW9ucy9sbG0tdGV4dGFyZWEtd2l0aC1hY3Rpb25zLmNvbXBvbmVudCc7XHJcbmltcG9ydCAqIGFzIGljb25zIGZyb20gJy4vaWNvbnMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdsaWItbGxtJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vbGxtLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9sbG0uY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIExMTUNvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgdGV4dCE6IHN0cmluZztcclxuICBASW5wdXQoKSBsYW5ndWFnZSE6IHN0cmluZztcclxuICBASW5wdXQoKSBpc01lbnVEaXNhYmxlZCE6IGJvb2xlYW47XHJcbiAgQElucHV0KCkgcmVwaHJhc2FibGVMYW5ndWFnZXNDb2RlTGlzdCA9IFsnZW4nXTtcclxuXHJcbiAgcmVhZG9ubHkgbGxtQWN0aW9uID0gTExNQWN0aW9ucztcclxuXHJcbiAgZ2V0IGlzVGV4dFN1bW1hcml6YWJsZSgpIHtcclxuICAgIHJldHVybiB0aGlzLnRleHQubGVuZ3RoID4gMTAwO1xyXG4gIH1cclxuXHJcbiAgZ2V0IGlzVGFyZ2V0TGFuZ3VhZ2VSZXBocmFzYWJsZSgpIHtcclxuICAgIHJldHVybiB0aGlzLnJlcGhyYXNhYmxlTGFuZ3VhZ2VzQ29kZUxpc3QuaW5jbHVkZXModGhpcy5sYW5ndWFnZVNlcnZpY2UucmVtb3ZlUmVnaW9uRnJvbUxhbmd1YWdlQ29kZSh0aGlzLmxhbmd1YWdlKSk7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBkaWFsb2c6IE1hdERpYWxvZywgXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IGljb25TZXJ2aWNlOiBJY29uU2VydmljZSwgXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IGxhbmd1YWdlU2VydmljZTogTGFuZ3VhZ2VUcmFuc2xhdGVTZXJ2aWNlXHJcbiAgKSB7XHJcbiAgICB0aGlzLmljb25TZXJ2aWNlLnJlZ2lzdGVySWNvbnMoaWNvbnMpO1xyXG4gIH1cclxuXHJcbiAgb3BlbkxMTU1vZGFsKGFjdGlvbjogTExNQWN0aW9ucyk6IHZvaWQge1xyXG4gICAgdGhpcy5kaWFsb2cub3BlbihMTE1UZXh0YXJlYVdpdGhBY3Rpb25zQ29tcG9uZW50LCB7XHJcbiAgICAgIHBhbmVsQ2xhc3M6ICdyZXNwb25zaXZlLWRpYWxvZycsXHJcbiAgICAgIG1heFdpZHRoOiAnODAwcHgnLFxyXG4gICAgICB3aWR0aDogJzEwMCUnLFxyXG4gICAgICBkYXRhOiB7XHJcbiAgICAgICAgdGV4dDogdGhpcy50ZXh0LFxyXG4gICAgICAgIGxhbmd1YWdlOiB0aGlzLmxhbmd1YWdlLFxyXG4gICAgICAgIGFjdGlvbjogYWN0aW9uXHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG4gIH1cclxufVxyXG4iLCI8YnV0dG9uXHJcbiAgW2Rpc2FibGVkXT1cImlzTWVudURpc2FibGVkXCJcclxuICBbbWF0VG9vbHRpcF09XCInTExNLk1FTlVfVE9PTFRJUCcgfCB0cmFuc2xhdGVcIlxyXG4gIG1hdC1pY29uLWJ1dHRvblxyXG4gIFttYXRNZW51VHJpZ2dlckZvcl09XCJtZW51XCJcclxuPlxyXG4gIDxtYXQtaWNvbiBzdmdJY29uPVwibGxtX21lbnVcIj48L21hdC1pY29uPlxyXG48L2J1dHRvbj5cclxuXHJcbjxtYXQtbWVudSAjbWVudT1cIm1hdE1lbnVcIj5cclxuICA8ZGl2IFttYXRUb29sdGlwXT1cIiFpc1RleHRTdW1tYXJpemFibGUgPyAoJ0xMTS5NRU5VX1NVTU1BUllfRElTQUJMRURfVE9PTFRJUCcgfCB0cmFuc2xhdGUpIDogJydcIj5cclxuICAgIDxidXR0b25cclxuICAgICAgbWF0LW1lbnUtaXRlbVxyXG4gICAgICBbZGlzYWJsZWRdPVwiIWlzVGV4dFN1bW1hcml6YWJsZVwiXHJcbiAgICAgIChjbGljayk9XCJvcGVuTExNTW9kYWwobGxtQWN0aW9uLlNVTU1BUlkpXCJcclxuICAgID5cclxuICAgICAge3sgXCJMTE0uU1VNTUFSWVwiIHwgdHJhbnNsYXRlIH19XHJcbiAgICA8L2J1dHRvbj5cclxuICA8L2Rpdj5cclxuXHJcbiAgPGRpdiBbbWF0VG9vbHRpcF09XCIhaXNUYXJnZXRMYW5ndWFnZVJlcGhyYXNhYmxlID8gKCdMTE0uTUVOVV9SRVBIUkFTRV9ESVNBQkxFRF9UT09MVElQJyB8IHRyYW5zbGF0ZSkgOiAnJ1wiPlxyXG4gICAgPGJ1dHRvblxyXG4gICAgICBtYXQtbWVudS1pdGVtXHJcbiAgICAgIFtkaXNhYmxlZF09XCIhaXNUYXJnZXRMYW5ndWFnZVJlcGhyYXNhYmxlXCJcclxuICAgICAgKGNsaWNrKT1cIm9wZW5MTE1Nb2RhbChsbG1BY3Rpb24uUkVQSFJBU0UpXCJcclxuICAgID5cclxuICAgICAge3sgXCJMTE0uUkVQSFJBU0VcIiB8IHRyYW5zbGF0ZSB9fVxyXG4gICAgPC9idXR0b24+XHJcbiAgPC9kaXY+XHJcbjwvbWF0LW1lbnU+XHJcbiJdfQ==
@@ -4449,9 +4449,6 @@ class LLMTextareaWithActionsComponent {
4449
4449
  get isDisabled() {
4450
4450
  return this.isLoading || !this.initialText || this.quotaLeft < 1;
4451
4451
  }
4452
- get showMissingQuotaMessage() {
4453
- return !this.quotaLeft && !this.missingQuotaMessageClosed && this.isQuotaLoaded;
4454
- }
4455
4452
  constructor(llmService, llmHelperService, data) {
4456
4453
  this.llmService = llmService;
4457
4454
  this.llmHelperService = llmHelperService;
@@ -4463,7 +4460,6 @@ class LLMTextareaWithActionsComponent {
4463
4460
  this.llmActions = LLMActions;
4464
4461
  this.writingStyles = Object.values(LLMWritingStyle);
4465
4462
  this.messages = [];
4466
- this.missingQuotaMessageClosed = false;
4467
4463
  }
4468
4464
  ngOnInit() {
4469
4465
  this.llmActionType = this.data.action;
@@ -4544,13 +4540,14 @@ class LLMTextareaWithActionsComponent {
4544
4540
  refreshQuota(decrease) {
4545
4541
  this.llmHelperService.getRemainingQuota(decrease).subscribe((remainingQuota) => {
4546
4542
  this.quotaLeft = remainingQuota;
4547
- this.isQuotaLoaded = true;
4548
4543
  this.setQuotaMessage();
4549
4544
  });
4550
4545
  }
4551
4546
  setQuotaMessage() {
4552
4547
  if (this.quotaLeft <= this.llmHelperService.trialRequestCount) {
4553
4548
  this.remainingQuotaMessageVisible = true;
4549
+ }
4550
+ if (this.quotaLeft < 1) {
4554
4551
  this.reachedQuotaMessage = this.llmHelperService.getReachedQuotaMessage();
4555
4552
  this.messages.push(this.reachedQuotaMessage);
4556
4553
  }
@@ -4635,7 +4632,8 @@ class LLMComponent {
4635
4632
  openLLMModal(action) {
4636
4633
  this.dialog.open(LLMTextareaWithActionsComponent, {
4637
4634
  panelClass: 'responsive-dialog',
4638
- maxWidth: '850px',
4635
+ maxWidth: '800px',
4636
+ width: '100%',
4639
4637
  data: {
4640
4638
  text: this.text,
4641
4639
  language: this.language,