@cuby-ui/core 0.0.274 → 0.0.276

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.
@@ -5,6 +5,7 @@ import type { CuiEditorConfig } from './interfaces';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare class CuiEditorComponent implements OnDestroy {
7
7
  private readonly destroy;
8
+ private readonly cuiIdService;
8
9
  private readonly editorService;
9
10
  private readonly jTextService;
10
11
  private readonly POOLING_DELAY;
@@ -12,11 +13,6 @@ export declare class CuiEditorComponent implements OnDestroy {
12
13
  private readonly SCROLL_THROTTLE_TIME;
13
14
  private readonly isReadonly;
14
15
  private readonly emptyQueue;
15
- protected readonly editorRef: ElementRef;
16
- readonly editorEmpty: EventEmitter<boolean>;
17
- editorID: string;
18
- config: CuiEditorConfig;
19
- requestSize: number;
20
16
  private poolingSubscription;
21
17
  private scrollSubscription;
22
18
  private isSkipCombinedBlockOnChange;
@@ -34,6 +30,12 @@ export declare class CuiEditorComponent implements OnDestroy {
34
30
  private removedBlocksIds;
35
31
  private changesQueue;
36
32
  private abortController;
33
+ protected readonly editorId: string;
34
+ protected readonly editorRef: ElementRef;
35
+ readonly editorEmpty: EventEmitter<boolean>;
36
+ editorApiId: string;
37
+ config: CuiEditorConfig;
38
+ requestSize: number;
37
39
  editor: EditorJS;
38
40
  editorElement: HTMLElement;
39
41
  ngOnChanges(changes: SimpleChanges): void;
@@ -67,5 +69,5 @@ export declare class CuiEditorComponent implements OnDestroy {
67
69
  private checkIsEmpty;
68
70
  private resetData;
69
71
  static ɵfac: i0.ɵɵFactoryDeclaration<CuiEditorComponent, never>;
70
- static ɵcmp: i0.ɵɵComponentDeclaration<CuiEditorComponent, "cui-editor", never, { "editorID": { "alias": "editorID"; "required": true; }; "config": { "alias": "config"; "required": false; }; "requestSize": { "alias": "requestSize"; "required": false; }; }, { "editorEmpty": "editorEmpty"; }, never, never, true, never>;
72
+ static ɵcmp: i0.ɵɵComponentDeclaration<CuiEditorComponent, "cui-editor", never, { "editorApiId": { "alias": "editorApiId"; "required": true; }; "config": { "alias": "config"; "required": false; }; "requestSize": { "alias": "requestSize"; "required": false; }; }, { "editorEmpty": "editorEmpty"; }, never, never, true, never>;
71
73
  }
@@ -1,5 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, computed, DestroyRef, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';
2
2
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
+ import { CuiIdService } from '@cuby-ui/cdk';
3
4
  import EditorJS from '@editorjs/editorjs';
4
5
  import { concatMap, delay, finalize, fromEvent, map, Subject, takeWhile, tap, throttleTime, timer, toArray } from 'rxjs';
5
6
  import { getEditorConfig } from './config';
@@ -11,6 +12,7 @@ import * as i0 from "@angular/core";
11
12
  export class CuiEditorComponent {
12
13
  constructor() {
13
14
  this.destroy = inject(DestroyRef);
15
+ this.cuiIdService = inject(CuiIdService);
14
16
  this.editorService = inject(CuiEditorService);
15
17
  this.jTextService = inject(CuiJTextApiService);
16
18
  this.POOLING_DELAY = 100;
@@ -18,9 +20,6 @@ export class CuiEditorComponent {
18
20
  this.SCROLL_THROTTLE_TIME = 200;
19
21
  this.isReadonly = computed(() => this.config?.readOnly);
20
22
  this.emptyQueue = new Subject();
21
- this.editorEmpty = new EventEmitter();
22
- this.config = DEFAULT_CONFIG;
23
- this.requestSize = 40;
24
23
  this.isSkipCombinedBlockOnChange = [];
25
24
  this.isFirst = true;
26
25
  this.isChanging = false;
@@ -36,9 +35,13 @@ export class CuiEditorComponent {
36
35
  this.removedBlocksIds = [];
37
36
  this.changesQueue = [];
38
37
  this.abortController = new AbortController();
38
+ this.editorId = this.cuiIdService.generate();
39
+ this.editorEmpty = new EventEmitter();
40
+ this.config = DEFAULT_CONFIG;
41
+ this.requestSize = 40;
39
42
  }
40
43
  ngOnChanges(changes) {
41
- if (changes['editorID'] || changes['config']) {
44
+ if (changes['editorApiId'] || changes['config']) {
42
45
  this.initEditorChanges();
43
46
  }
44
47
  }
@@ -105,7 +108,7 @@ export class CuiEditorComponent {
105
108
  }
106
109
  initEditorChanges() {
107
110
  this.jTextService.addOptions(this.config.requestOptions);
108
- this.editor = this.initEditor(this.editorID);
111
+ this.editor = this.initEditor(this.editorId);
109
112
  this.editor.isReady.then(() => {
110
113
  if (this.isDestroyed) {
111
114
  return;
@@ -209,7 +212,7 @@ export class CuiEditorComponent {
209
212
  return { ...block, index };
210
213
  });
211
214
  const addedBlocks = [...defaultBlocksWithIndex, ...combinedBlocksWithIndex].sort((first, second) => first.index - second.index);
212
- const addBlocks$ = this.editorService.collectAddedBlocksRequest(this.editorID, addedBlocks);
215
+ const addBlocks$ = this.editorService.collectAddedBlocksRequest(this.editorApiId, addedBlocks);
213
216
  return {
214
217
  addedBlocks,
215
218
  addBlocks$
@@ -230,13 +233,13 @@ export class CuiEditorComponent {
230
233
  const id = block.detail.target.id;
231
234
  this.removedBlocksIds.push(id);
232
235
  });
233
- const removeBlocks$ = this.editorService.collectRemovedBlocksRequest(this.editorID, this.removedBlocksIds, this.blockIdsMap);
236
+ const removeBlocks$ = this.editorService.collectRemovedBlocksRequest(this.editorApiId, this.removedBlocksIds, this.blockIdsMap);
234
237
  this.removedBlocksIds = [];
235
238
  return removeBlocks$;
236
239
  }
237
240
  getBlocks(page = 0, size = 40) {
238
241
  let combinedBlock;
239
- return this.jTextService.getBlocks(this.editorID, page, size).pipe(takeUntilDestroyed(this.destroy), finalize(() => {
242
+ return this.jTextService.getBlocks(this.editorApiId, page, size).pipe(takeUntilDestroyed(this.destroy), finalize(() => {
240
243
  if (combinedBlock) {
241
244
  this.addCombinedBlock(combinedBlock);
242
245
  combinedBlock = null;
@@ -327,7 +330,7 @@ export class CuiEditorComponent {
327
330
  this.editor.render({ blocks: [] });
328
331
  return;
329
332
  }
330
- this.editorService.setStartBlock(this.editorID, async (block, id) => {
333
+ this.editorService.setStartBlock(this.editorApiId, async (block, id) => {
331
334
  this.blockIdsMap.set(id, id);
332
335
  this.isSkipCombinedBlockOnChange.push(true);
333
336
  await this.editor.render({ blocks: [block] });
@@ -367,17 +370,17 @@ export class CuiEditorComponent {
367
370
  this.abortController = new AbortController();
368
371
  }
369
372
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
370
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CuiEditorComponent, isStandalone: true, selector: "cui-editor", inputs: { editorID: "editorID", config: "config", requestSize: "requestSize" }, outputs: { editorEmpty: "editorEmpty" }, providers: [CuiEditorService, CuiJTextApiService], viewQueries: [{ propertyName: "editorRef", first: true, predicate: ["editor"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n #editor\n [id]=\"editorID\"\n [class._readonly]=\"config.readOnly\"\n data-editor\n></div>\n", styles: [":host{--textColor: var(--cui-base-900);--menuBackground: var(--cui-base-0);--menuBorder: var(--cui-base-200);--menuItemHover: var(--cui-base-10);--menuItemBackground: var(cui-base-900);--menuIconBackground: var(--cui-base-50);--menuIconHover: var(--cui-base-10);font-weight:400;font-size:14px;line-height:20px;font-family:var(--cui-main-font)}:host ::ng-deep .ce-popover{--color-background: var(--menuBackground);--color-text-primary: var(--textColor);--color-border: var(--menuBorder);--color-border-icon: var(--menuBorder);--color-background-item: var(--menuItemBackground);--color-background-item-hover: var(--menuItemHover)}:host ::ng-deep .ce-popover__search{background:var(--menuIconBackground)}:host ::ng-deep .ce-popover .ce-popover-item__icon{background:var(--menuIconBackground)}:host ::ng-deep .ce-conversion-toolbar{background-color:var(--menuBackground);border-color:var(--menuBorder)}:host ::ng-deep .ce-conversion-toolbar__tools{padding:0 6px 6px}:host ::ng-deep .ce-conversion-tool{padding:3px;border-radius:6px}:host ::ng-deep .ce-conversion-tool__icon{border:1px solid var(--menuBorder);background-color:var(--menuIconBackground);box-shadow:none}:host ::ng-deep .ce-conversion-tool:hover{background-color:var(--menuItemHover)}:host ::ng-deep .ce-conversion-tool:hover .ce-conversion-tool__icon{border-color:var(--menuIconHover)}:host ::ng-deep .combined-text-block{padding:.4em 0;line-height:1.6em;outline:none}:host ::ng-deep .combined-text-block .combined-text-block-part{outline:none}:host ::ng-deep .combined-text-block .combined-text-block-part:only-child,:host ::ng-deep .combined-text-block .combined-text-block-part._selected{display:list-item}:host ::ng-deep .combined-text-block .combined-text-block-part:only-child::marker,:host ::ng-deep .combined-text-block .combined-text-block-part._selected::marker{content:\"\"}:host ::ng-deep .image-tool__image{border:1px solid var(--cui-base-200);background-color:var(--cui-base-0)}:host ::ng-deep .image-tool__image-preloader{background-color:var(--cui-base-200)}:host ::ng-deep .image-tool__image-preloader:after{border:1px solid var(--cui-base-200);border-top:1px solid var(--cui-blue-600)}:host ::ng-deep .cdx-button{border:1px solid var(--cui-base-200);color:var(--textColor);background-color:var(--cui-base-0);box-shadow:none}:host ::ng-deep .ce-inline-toolbar{border-color:var(--cui-base-100);color:var(--textColor);background-color:var(--cui-base-0)}:host ::ng-deep .ce-inline-toolbar__dropdown:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-inline-tool:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-toolbar__plus,:host ::ng-deep .ce-toolbar__settings-btn{color:var(--cui-base-500)}:host ::ng-deep .ce-toolbar__plus:hover,:host ::ng-deep .ce-toolbar__settings-btn:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-toolbar__actions{right:100%}:host ::ng-deep .ce-toolbar__content{max-width:none}:host ::ng-deep .ce-block--selected .ce-block__content{background-color:var(--cui-base-200)}:host ::ng-deep .ce-block__content{max-width:100%}:host ::ng-deep .ce-block:only-of-type .combined-text-block[data-placeholder-active][data-empty=true]:before{content:attr(data-placeholder-active);position:absolute;color:var(--cui-base-400)}:host ::ng-deep [data-editor]{padding-right:4px;width:100%;height:100%;min-height:200px;overflow:hidden auto;scrollbar-gutter:stable}:host ::ng-deep [data-editor] .codex-editor{margin-left:60px}:host ::ng-deep [data-editor] .codex-editor--narrow .ce-popover{right:auto}:host ::ng-deep [data-editor] .codex-editor__redactor{margin-right:auto;padding-bottom:260px!important}:host ::ng-deep [data-editor]._readonly{min-height:auto}:host ::ng-deep [data-editor]._readonly .codex-editor{margin:auto}:host ::ng-deep [data-editor]._readonly .codex-editor__redactor{padding-bottom:0!important}:host ::ng-deep [data-editor]._readonly .combined-text-block{padding:0}:host ::ng-deep [data-editor] [data-item-name=move-up],:host ::ng-deep [data-editor] [data-item-name=move-down],:host ::ng-deep [data-editor] [data-tool=paragraph]{display:none}:host ::ng-deep [data-editor] *::selection{background:var(--cui-base-200)}:host ::ng-deep [data-editor] a{color:var(--cui-light-blue-600)}:host ::ng-deep .marker{cursor:pointer;text-decoration:underline;color:var(--cui-light-blue-600);background-color:transparent}:host ::ng-deep .tool-marker,:host ::ng-deep .role-marker{margin:0 5px}:host ::ng-deep .tool-marker{color:#e97c00}:host ::ng-deep .role-marker{color:#8803f1}.form{height:100%}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
373
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CuiEditorComponent, isStandalone: true, selector: "cui-editor", inputs: { editorApiId: "editorApiId", config: "config", requestSize: "requestSize" }, outputs: { editorEmpty: "editorEmpty" }, providers: [CuiEditorService, CuiJTextApiService], viewQueries: [{ propertyName: "editorRef", first: true, predicate: ["editor"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n #editor\n [id]=\"editorId\"\n data-editor\n [class._readonly]=\"config.readOnly\"\n></div>\n", styles: [":host{--textColor: var(--cui-base-900);--menuBackground: var(--cui-base-0);--menuBorder: var(--cui-base-200);--menuItemHover: var(--cui-base-10);--menuItemBackground: var(cui-base-900);--menuIconBackground: var(--cui-base-50);--menuIconHover: var(--cui-base-10);font-weight:400;font-size:14px;line-height:20px;font-family:var(--cui-main-font)}:host ::ng-deep .ce-popover{--color-background: var(--menuBackground);--color-text-primary: var(--textColor);--color-border: var(--menuBorder);--color-border-icon: var(--menuBorder);--color-background-item: var(--menuItemBackground);--color-background-item-hover: var(--menuItemHover)}:host ::ng-deep .ce-popover__search{background:var(--menuIconBackground)}:host ::ng-deep .ce-popover .ce-popover-item__icon{background:var(--menuIconBackground)}:host ::ng-deep .ce-conversion-toolbar{background-color:var(--menuBackground);border-color:var(--menuBorder)}:host ::ng-deep .ce-conversion-toolbar__tools{padding:0 6px 6px}:host ::ng-deep .ce-conversion-tool{padding:3px;border-radius:6px}:host ::ng-deep .ce-conversion-tool__icon{border:1px solid var(--menuBorder);background-color:var(--menuIconBackground);box-shadow:none}:host ::ng-deep .ce-conversion-tool:hover{background-color:var(--menuItemHover)}:host ::ng-deep .ce-conversion-tool:hover .ce-conversion-tool__icon{border-color:var(--menuIconHover)}:host ::ng-deep .combined-text-block{padding:.4em 0;line-height:1.6em;outline:none}:host ::ng-deep .combined-text-block .combined-text-block-part{outline:none}:host ::ng-deep .combined-text-block .combined-text-block-part:only-child,:host ::ng-deep .combined-text-block .combined-text-block-part._selected{display:list-item}:host ::ng-deep .combined-text-block .combined-text-block-part:only-child::marker,:host ::ng-deep .combined-text-block .combined-text-block-part._selected::marker{content:\"\"}:host ::ng-deep .image-tool__image{border:1px solid var(--cui-base-200);background-color:var(--cui-base-0)}:host ::ng-deep .image-tool__image-preloader{background-color:var(--cui-base-200)}:host ::ng-deep .image-tool__image-preloader:after{border:1px solid var(--cui-base-200);border-top:1px solid var(--cui-blue-600)}:host ::ng-deep .cdx-button{border:1px solid var(--cui-base-200);color:var(--textColor);background-color:var(--cui-base-0);box-shadow:none}:host ::ng-deep .ce-inline-toolbar{border-color:var(--cui-base-100);color:var(--textColor);background-color:var(--cui-base-0)}:host ::ng-deep .ce-inline-toolbar__dropdown:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-inline-tool:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-toolbar__plus,:host ::ng-deep .ce-toolbar__settings-btn{color:var(--cui-base-500)}:host ::ng-deep .ce-toolbar__plus:hover,:host ::ng-deep .ce-toolbar__settings-btn:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-toolbar__actions{right:100%}:host ::ng-deep .ce-toolbar__content{max-width:none}:host ::ng-deep .ce-block--selected .ce-block__content{background-color:var(--cui-base-200)}:host ::ng-deep .ce-block__content{max-width:100%}:host ::ng-deep .ce-block:only-of-type .combined-text-block[data-placeholder-active][data-empty=true]:before{content:attr(data-placeholder-active);position:absolute;color:var(--cui-base-400)}:host ::ng-deep [data-editor]{padding-right:4px;width:100%;height:100%;min-height:200px;overflow:hidden auto;scrollbar-gutter:stable}:host ::ng-deep [data-editor] .codex-editor{margin-left:60px}:host ::ng-deep [data-editor] .codex-editor--narrow .ce-popover{right:auto}:host ::ng-deep [data-editor] .codex-editor__redactor{margin-right:auto;padding-bottom:260px!important}:host ::ng-deep [data-editor]._readonly{min-height:auto}:host ::ng-deep [data-editor]._readonly .codex-editor{margin:auto}:host ::ng-deep [data-editor]._readonly .codex-editor__redactor{padding-bottom:0!important}:host ::ng-deep [data-editor]._readonly .combined-text-block{padding:0}:host ::ng-deep [data-editor] [data-item-name=move-up],:host ::ng-deep [data-editor] [data-item-name=move-down],:host ::ng-deep [data-editor] [data-tool=paragraph]{display:none}:host ::ng-deep [data-editor] *::selection{background:var(--cui-base-200)}:host ::ng-deep [data-editor] a{color:var(--cui-light-blue-600)}:host ::ng-deep .marker{cursor:pointer;text-decoration:underline;color:var(--cui-light-blue-600);background-color:transparent}:host ::ng-deep .tool-marker,:host ::ng-deep .role-marker{margin:0 5px}:host ::ng-deep .tool-marker{color:#e97c00}:host ::ng-deep .role-marker{color:#8803f1}.form{height:100%}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
371
374
  }
372
375
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiEditorComponent, decorators: [{
373
376
  type: Component,
374
- args: [{ selector: 'cui-editor', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, providers: [CuiEditorService, CuiJTextApiService], template: "<div\n #editor\n [id]=\"editorID\"\n [class._readonly]=\"config.readOnly\"\n data-editor\n></div>\n", styles: [":host{--textColor: var(--cui-base-900);--menuBackground: var(--cui-base-0);--menuBorder: var(--cui-base-200);--menuItemHover: var(--cui-base-10);--menuItemBackground: var(cui-base-900);--menuIconBackground: var(--cui-base-50);--menuIconHover: var(--cui-base-10);font-weight:400;font-size:14px;line-height:20px;font-family:var(--cui-main-font)}:host ::ng-deep .ce-popover{--color-background: var(--menuBackground);--color-text-primary: var(--textColor);--color-border: var(--menuBorder);--color-border-icon: var(--menuBorder);--color-background-item: var(--menuItemBackground);--color-background-item-hover: var(--menuItemHover)}:host ::ng-deep .ce-popover__search{background:var(--menuIconBackground)}:host ::ng-deep .ce-popover .ce-popover-item__icon{background:var(--menuIconBackground)}:host ::ng-deep .ce-conversion-toolbar{background-color:var(--menuBackground);border-color:var(--menuBorder)}:host ::ng-deep .ce-conversion-toolbar__tools{padding:0 6px 6px}:host ::ng-deep .ce-conversion-tool{padding:3px;border-radius:6px}:host ::ng-deep .ce-conversion-tool__icon{border:1px solid var(--menuBorder);background-color:var(--menuIconBackground);box-shadow:none}:host ::ng-deep .ce-conversion-tool:hover{background-color:var(--menuItemHover)}:host ::ng-deep .ce-conversion-tool:hover .ce-conversion-tool__icon{border-color:var(--menuIconHover)}:host ::ng-deep .combined-text-block{padding:.4em 0;line-height:1.6em;outline:none}:host ::ng-deep .combined-text-block .combined-text-block-part{outline:none}:host ::ng-deep .combined-text-block .combined-text-block-part:only-child,:host ::ng-deep .combined-text-block .combined-text-block-part._selected{display:list-item}:host ::ng-deep .combined-text-block .combined-text-block-part:only-child::marker,:host ::ng-deep .combined-text-block .combined-text-block-part._selected::marker{content:\"\"}:host ::ng-deep .image-tool__image{border:1px solid var(--cui-base-200);background-color:var(--cui-base-0)}:host ::ng-deep .image-tool__image-preloader{background-color:var(--cui-base-200)}:host ::ng-deep .image-tool__image-preloader:after{border:1px solid var(--cui-base-200);border-top:1px solid var(--cui-blue-600)}:host ::ng-deep .cdx-button{border:1px solid var(--cui-base-200);color:var(--textColor);background-color:var(--cui-base-0);box-shadow:none}:host ::ng-deep .ce-inline-toolbar{border-color:var(--cui-base-100);color:var(--textColor);background-color:var(--cui-base-0)}:host ::ng-deep .ce-inline-toolbar__dropdown:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-inline-tool:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-toolbar__plus,:host ::ng-deep .ce-toolbar__settings-btn{color:var(--cui-base-500)}:host ::ng-deep .ce-toolbar__plus:hover,:host ::ng-deep .ce-toolbar__settings-btn:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-toolbar__actions{right:100%}:host ::ng-deep .ce-toolbar__content{max-width:none}:host ::ng-deep .ce-block--selected .ce-block__content{background-color:var(--cui-base-200)}:host ::ng-deep .ce-block__content{max-width:100%}:host ::ng-deep .ce-block:only-of-type .combined-text-block[data-placeholder-active][data-empty=true]:before{content:attr(data-placeholder-active);position:absolute;color:var(--cui-base-400)}:host ::ng-deep [data-editor]{padding-right:4px;width:100%;height:100%;min-height:200px;overflow:hidden auto;scrollbar-gutter:stable}:host ::ng-deep [data-editor] .codex-editor{margin-left:60px}:host ::ng-deep [data-editor] .codex-editor--narrow .ce-popover{right:auto}:host ::ng-deep [data-editor] .codex-editor__redactor{margin-right:auto;padding-bottom:260px!important}:host ::ng-deep [data-editor]._readonly{min-height:auto}:host ::ng-deep [data-editor]._readonly .codex-editor{margin:auto}:host ::ng-deep [data-editor]._readonly .codex-editor__redactor{padding-bottom:0!important}:host ::ng-deep [data-editor]._readonly .combined-text-block{padding:0}:host ::ng-deep [data-editor] [data-item-name=move-up],:host ::ng-deep [data-editor] [data-item-name=move-down],:host ::ng-deep [data-editor] [data-tool=paragraph]{display:none}:host ::ng-deep [data-editor] *::selection{background:var(--cui-base-200)}:host ::ng-deep [data-editor] a{color:var(--cui-light-blue-600)}:host ::ng-deep .marker{cursor:pointer;text-decoration:underline;color:var(--cui-light-blue-600);background-color:transparent}:host ::ng-deep .tool-marker,:host ::ng-deep .role-marker{margin:0 5px}:host ::ng-deep .tool-marker{color:#e97c00}:host ::ng-deep .role-marker{color:#8803f1}.form{height:100%}\n"] }]
377
+ args: [{ selector: 'cui-editor', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, providers: [CuiEditorService, CuiJTextApiService], template: "<div\n #editor\n [id]=\"editorId\"\n data-editor\n [class._readonly]=\"config.readOnly\"\n></div>\n", styles: [":host{--textColor: var(--cui-base-900);--menuBackground: var(--cui-base-0);--menuBorder: var(--cui-base-200);--menuItemHover: var(--cui-base-10);--menuItemBackground: var(cui-base-900);--menuIconBackground: var(--cui-base-50);--menuIconHover: var(--cui-base-10);font-weight:400;font-size:14px;line-height:20px;font-family:var(--cui-main-font)}:host ::ng-deep .ce-popover{--color-background: var(--menuBackground);--color-text-primary: var(--textColor);--color-border: var(--menuBorder);--color-border-icon: var(--menuBorder);--color-background-item: var(--menuItemBackground);--color-background-item-hover: var(--menuItemHover)}:host ::ng-deep .ce-popover__search{background:var(--menuIconBackground)}:host ::ng-deep .ce-popover .ce-popover-item__icon{background:var(--menuIconBackground)}:host ::ng-deep .ce-conversion-toolbar{background-color:var(--menuBackground);border-color:var(--menuBorder)}:host ::ng-deep .ce-conversion-toolbar__tools{padding:0 6px 6px}:host ::ng-deep .ce-conversion-tool{padding:3px;border-radius:6px}:host ::ng-deep .ce-conversion-tool__icon{border:1px solid var(--menuBorder);background-color:var(--menuIconBackground);box-shadow:none}:host ::ng-deep .ce-conversion-tool:hover{background-color:var(--menuItemHover)}:host ::ng-deep .ce-conversion-tool:hover .ce-conversion-tool__icon{border-color:var(--menuIconHover)}:host ::ng-deep .combined-text-block{padding:.4em 0;line-height:1.6em;outline:none}:host ::ng-deep .combined-text-block .combined-text-block-part{outline:none}:host ::ng-deep .combined-text-block .combined-text-block-part:only-child,:host ::ng-deep .combined-text-block .combined-text-block-part._selected{display:list-item}:host ::ng-deep .combined-text-block .combined-text-block-part:only-child::marker,:host ::ng-deep .combined-text-block .combined-text-block-part._selected::marker{content:\"\"}:host ::ng-deep .image-tool__image{border:1px solid var(--cui-base-200);background-color:var(--cui-base-0)}:host ::ng-deep .image-tool__image-preloader{background-color:var(--cui-base-200)}:host ::ng-deep .image-tool__image-preloader:after{border:1px solid var(--cui-base-200);border-top:1px solid var(--cui-blue-600)}:host ::ng-deep .cdx-button{border:1px solid var(--cui-base-200);color:var(--textColor);background-color:var(--cui-base-0);box-shadow:none}:host ::ng-deep .ce-inline-toolbar{border-color:var(--cui-base-100);color:var(--textColor);background-color:var(--cui-base-0)}:host ::ng-deep .ce-inline-toolbar__dropdown:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-inline-tool:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-toolbar__plus,:host ::ng-deep .ce-toolbar__settings-btn{color:var(--cui-base-500)}:host ::ng-deep .ce-toolbar__plus:hover,:host ::ng-deep .ce-toolbar__settings-btn:hover{background-color:var(--cui-base-100)}:host ::ng-deep .ce-toolbar__actions{right:100%}:host ::ng-deep .ce-toolbar__content{max-width:none}:host ::ng-deep .ce-block--selected .ce-block__content{background-color:var(--cui-base-200)}:host ::ng-deep .ce-block__content{max-width:100%}:host ::ng-deep .ce-block:only-of-type .combined-text-block[data-placeholder-active][data-empty=true]:before{content:attr(data-placeholder-active);position:absolute;color:var(--cui-base-400)}:host ::ng-deep [data-editor]{padding-right:4px;width:100%;height:100%;min-height:200px;overflow:hidden auto;scrollbar-gutter:stable}:host ::ng-deep [data-editor] .codex-editor{margin-left:60px}:host ::ng-deep [data-editor] .codex-editor--narrow .ce-popover{right:auto}:host ::ng-deep [data-editor] .codex-editor__redactor{margin-right:auto;padding-bottom:260px!important}:host ::ng-deep [data-editor]._readonly{min-height:auto}:host ::ng-deep [data-editor]._readonly .codex-editor{margin:auto}:host ::ng-deep [data-editor]._readonly .codex-editor__redactor{padding-bottom:0!important}:host ::ng-deep [data-editor]._readonly .combined-text-block{padding:0}:host ::ng-deep [data-editor] [data-item-name=move-up],:host ::ng-deep [data-editor] [data-item-name=move-down],:host ::ng-deep [data-editor] [data-tool=paragraph]{display:none}:host ::ng-deep [data-editor] *::selection{background:var(--cui-base-200)}:host ::ng-deep [data-editor] a{color:var(--cui-light-blue-600)}:host ::ng-deep .marker{cursor:pointer;text-decoration:underline;color:var(--cui-light-blue-600);background-color:transparent}:host ::ng-deep .tool-marker,:host ::ng-deep .role-marker{margin:0 5px}:host ::ng-deep .tool-marker{color:#e97c00}:host ::ng-deep .role-marker{color:#8803f1}.form{height:100%}\n"] }]
375
378
  }], propDecorators: { editorRef: [{
376
379
  type: ViewChild,
377
380
  args: ['editor']
378
381
  }], editorEmpty: [{
379
382
  type: Output
380
- }], editorID: [{
383
+ }], editorApiId: [{
381
384
  type: Input,
382
385
  args: [{ required: true }]
383
386
  }], config: [{
@@ -385,4 +388,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
385
388
  }], requestSize: [{
386
389
  type: Input
387
390
  }] } });
388
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../projects/core/editor/editor.component.ts","../../../../projects/core/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import type { ElementRef, OnDestroy, SimpleChanges } from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    DestroyRef,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport type { CuiNullable } from '@cuby-ui/cdk';\nimport type { API, BlockMutationEvent, OutputData } from '@editorjs/editorjs';\nimport EditorJS from '@editorjs/editorjs';\nimport type { Observable, Subscription } from 'rxjs';\nimport {\n    concatMap,\n    delay,\n    finalize,\n    fromEvent,\n    map,\n    Subject,\n    takeWhile,\n    tap,\n    throttleTime,\n    timer,\n    toArray\n} from 'rxjs';\n\nimport { getEditorConfig } from './config';\nimport {\n    COMBINED_TEXT_BLOCK_NAME,\n    COMBINED_TEXT_BLOCK_PART,\n    DEFAULT_CONFIG\n} from './constants/editor.constants';\nimport { setEditorEvents } from './events/set-editor-events';\nimport type {\n    CuiBlockData,\n    CuiBlocksRequestData,\n    CuiCombinedBlockAddingEvent,\n    CuiCombinedBlockToolData,\n    CuiCombinedPartBlock,\n    CuiEditorConfig,\n    CuiEventActionData,\n    CuiFullBlockData\n} from './interfaces';\nimport { Block, CuiEditorService, CuiJTextApiService, EventActions } from './services';\nimport { recalculateIndexes } from './utils/recalculate-indexes';\n\n@Component({\n    selector: 'cui-editor',\n    standalone: true,\n    templateUrl: './editor.component.html',\n    styleUrls: ['./editor.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [CuiEditorService, CuiJTextApiService]\n})\nexport class CuiEditorComponent implements OnDestroy {\n    private readonly destroy = inject(DestroyRef);\n    private readonly editorService = inject(CuiEditorService);\n    private readonly jTextService = inject(CuiJTextApiService);\n\n    private readonly POOLING_DELAY = 100;\n    private readonly ELEMENT_SPACE_TO_BOTTOM = 150;\n    private readonly SCROLL_THROTTLE_TIME = 200;\n\n    private readonly isReadonly = computed(() => this.config?.readOnly);\n    private readonly emptyQueue = new Subject();\n\n    @ViewChild('editor')\n    protected readonly editorRef!: ElementRef;\n\n    @Output()\n    public readonly editorEmpty = new EventEmitter<boolean>();\n\n    @Input({ required: true })\n    public editorID!: string;\n\n    @Input()\n    public config: CuiEditorConfig = DEFAULT_CONFIG;\n\n    @Input()\n    public requestSize = 40;\n\n    private poolingSubscription!: Subscription;\n    private scrollSubscription!: Subscription;\n    private isSkipCombinedBlockOnChange: boolean[] = [];\n    private isFirst = true;\n    private isChanging = false;\n    private isSkip = false;\n    private isRequested = false;\n    private isDestroyed = false;\n    private blockIdsMap = new Map<string, string>();\n    private combinedBlocks = new Map();\n    private index = 0;\n    private page = 0;\n    private addedBlocks: CuiBlockData[] = [];\n    private updatedBlocks: Block[] = [];\n    private removedBlocksIds: string[] = [];\n    private changesQueue: BlockMutationEvent[][] = [];\n    private abortController = new AbortController();\n\n    public editor!: EditorJS;\n    public editorElement!: HTMLElement;\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes['editorID'] || changes['config']) {\n            this.initEditorChanges();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.isDestroyed = true;\n        this.destroyEditor();\n    }\n\n    private onScrollEvent(element: HTMLElement): void {\n        const overallHeight = element.scrollHeight - this.ELEMENT_SPACE_TO_BOTTOM;\n        const currentHeight = element.scrollTop + element.clientHeight;\n\n        if (currentHeight < overallHeight || this.isRequested) {\n            return;\n        }\n\n        this.isRequested = true;\n\n        const size = this.requestSize;\n        let blocksCount = 0;\n\n        this.getBlocks(this.page, size)\n            .pipe(\n                tap((blocks) => (blocksCount = blocks.length)),\n                finalize(() => {\n                    this.isRequested = false;\n\n                    if (blocksCount >= size) {\n                        return;\n                    }\n\n                    this.scrollSubscription.unsubscribe();\n                })\n            )\n            .subscribe();\n\n        this.page++;\n    }\n\n    private onEditorChange(_: API, event: BlockMutationEvent | BlockMutationEvent[]): void {\n        if (this.isReadonly() || this.isDestroyed) {\n            return;\n        }\n\n        if (!Array.isArray(event)) {\n            event = [event];\n        }\n\n        recalculateIndexes(this.editor.blocks);\n\n        if (this.isChanging) {\n            this.changesQueue.unshift(event);\n        }\n\n        this.startChanges(event);\n        this.editorEmpty.emit(this.checkIsEmpty());\n    }\n\n    private onAddedCombinedBlock(data: CuiCombinedBlockAddingEvent): void {\n        if (this.isSkipCombinedBlockOnChange.length) {\n            this.isSkipCombinedBlockOnChange.pop();\n\n            return;\n        }\n\n        const blocksWithoutId = data.blocks.map((block) => ({\n            block: { ...block, id: undefined },\n            id: block.id!\n        }));\n\n        this.addedBlocks.push(...blocksWithoutId);\n    }\n\n    private onUpdatedCombinedBlock(updatedBlocks: Block[]): void {\n        if (!updatedBlocks.length) {\n            return;\n        }\n\n        this.updatedBlocks.push(...updatedBlocks);\n    }\n\n    private onRemovedCombinedBlock(blockIds: string[]): void {\n        if (!blockIds.length) {\n            return;\n        }\n\n        this.removedBlocksIds.push(...blockIds);\n    }\n\n    private initEditorChanges(): void {\n        this.jTextService.addOptions(this.config.requestOptions);\n\n        this.editor = this.initEditor(this.editorID);\n        this.editor.isReady.then(() => {\n            if (this.isDestroyed) {\n                return;\n            }\n\n            this.editorElement = this.editorRef.nativeElement;\n\n            this.initEditorEvents(this.editorElement);\n            this.initScrollObserver();\n            this.startPooling(this.requestSize);\n            this.setListenersOnCustomBlockChanges();\n        });\n    }\n\n    private initEditor(id: string): EditorJS {\n        const config = this.config;\n\n        this.destroyEditor();\n        this.editor = new EditorJS({\n            ...getEditorConfig(id, config),\n            onChange: this.onEditorChange.bind(this)\n        });\n\n        return this.editor;\n    }\n\n    private initScrollObserver(): void {\n        const element = this.config?.element ?? this.editorElement;\n        const scrollObserver = fromEvent(element, 'scroll');\n\n        this.scrollSubscription = scrollObserver\n            .pipe(\n                takeUntilDestroyed(this.destroy),\n                throttleTime(this.SCROLL_THROTTLE_TIME, undefined, {\n                    leading: true,\n                    trailing: true\n                }),\n                map(() => this.onScrollEvent(element))\n            )\n            .subscribe();\n    }\n\n    private initEditorEvents(element: HTMLElement): void {\n        const readOnly = this.isReadonly();\n\n        if (readOnly) {\n            return;\n        }\n\n        setEditorEvents(element, this.abortController.signal);\n    }\n\n    private startPooling(size: number): void {\n        const scrollElement = this.config?.element ?? this.editorElement;\n        const withoutPreload = this.config?.withoutPreload;\n\n        this.poolingSubscription = timer(0, this.POOLING_DELAY)\n            .pipe(\n                concatMap(() => this.getBlocks(this.page, size).pipe(delay(this.POOLING_DELAY))),\n                tap(() => this.page++),\n                takeWhile(\n                    (blocks) =>\n                        !withoutPreload &&\n                        scrollElement.scrollHeight <= scrollElement.clientHeight &&\n                        blocks.length >= size\n                ),\n                finalize(() => {\n                    if (this.isDestroyed) {\n                        return;\n                    }\n\n                    this.setStartBlock();\n                })\n            )\n            .subscribe();\n    }\n\n    private destroyEditor(): void {\n        this.abortController.abort();\n        this.resetData();\n        // TODO: в рандом кейсах падает ошибка если убрать проверку на вызов destroy\n        this.editor?.destroy?.();\n    }\n\n    private setListenersOnCustomBlockChanges(): void {\n        this.editorService.setListenersOnCustomBlockChanges(this.editor, {\n            removedCallback: this.onRemovedCombinedBlock.bind(this),\n            updatedCallback: this.onUpdatedCombinedBlock.bind(this),\n            addedCallback: this.onAddedCombinedBlock.bind(this)\n        });\n    }\n\n    private async startChanges(event: BlockMutationEvent[]): Promise<void> {\n        if (this.isSkip || this.isChanging) {\n            this.isSkip = false;\n\n            return;\n        }\n\n        this.isChanging = true;\n\n        try {\n            const editorOutput = await this.editor.save();\n            const events = event.filter((data) => data.detail.target.name !== COMBINED_TEXT_BLOCK_NAME);\n            const blocks = this.editorService.sortEventsByTypes(events);\n            const { addBlocks$, addedBlocks } = this.collectAddedBlocksRequest(blocks, editorOutput);\n\n            this.addedBlocks = [];\n\n            addBlocks$\n                .pipe(\n                    tap((blockIds) => this.setBlockIdsToMap(blockIds, addedBlocks)),\n                    concatMap(() => this.collectUpdatedBlocksRequest(blocks, editorOutput)),\n                    concatMap(() => this.collectRemovedBlocksRequest(blocks))\n                )\n                .subscribe({\n                    complete: () => this.startNextChange(),\n                    error: () => this.startNextChange()\n                });\n        } catch (e) {\n            return;\n        }\n    }\n\n    private startNextChange(): void {\n        this.isChanging = false;\n\n        const nextEvents = this.changesQueue.pop();\n\n        if (nextEvents) {\n            this.startChanges(nextEvents);\n        }\n\n        this.emptyQueue.next(null);\n    }\n\n    private collectAddedBlocksRequest(blocks: CuiEventActionData, editorOutput: OutputData): CuiBlocksRequestData {\n        const defaultBlocksWithIndex = blocks[EventActions.add].map((addedBlock) =>\n            this.editorService.getFullBlockData(addedBlock, editorOutput)\n        );\n        const combinedBlocksWithIndex = this.addedBlocks.map((block) => {\n            const element = this.editorElement.querySelector(`[data-id=\"${block.id}\"]`) as HTMLElement;\n            const index = Number(element?.dataset['index']);\n\n            return { ...block, index };\n        });\n\n        const addedBlocks = [...defaultBlocksWithIndex, ...combinedBlocksWithIndex].sort((first, second) => first.index - second.index);\n        const addBlocks$ = this.editorService.collectAddedBlocksRequest(this.editorID, addedBlocks);\n\n        return {\n            addedBlocks,\n            addBlocks$\n        };\n    }\n\n    private collectUpdatedBlocksRequest(blocks: CuiEventActionData, editorOutput: OutputData): Observable<Block[]> {\n        blocks[EventActions.update].forEach((updateBlock) => {\n            const { id, block } = this.editorService.getFullBlockData(updateBlock, editorOutput);\n            block.id = id;\n\n            this.updatedBlocks.push(block);\n        });\n\n        const updateBlocks$ = this.editorService.collectUpdatedBlocksRequest(this.updatedBlocks, this.blockIdsMap);\n\n        this.updatedBlocks = [];\n\n        return updateBlocks$;\n    }\n\n    private collectRemovedBlocksRequest(blocks: CuiEventActionData): Observable<void> {\n        blocks[EventActions.remove].forEach((block) => {\n            const id = block.detail.target.id;\n\n            this.removedBlocksIds.push(id);\n        });\n\n        const removeBlocks$ = this.editorService.collectRemovedBlocksRequest(\n            this.editorID,\n            this.removedBlocksIds,\n            this.blockIdsMap\n        );\n        this.removedBlocksIds = [];\n\n        return removeBlocks$;\n    }\n\n    private getBlocks(page = 0, size = 40): Observable<Block[]> {\n        let combinedBlock: CuiNullable<Block>;\n\n        return this.jTextService.getBlocks(this.editorID, page, size).pipe(\n            takeUntilDestroyed(this.destroy),\n            finalize(() => {\n                if (combinedBlock) {\n                    this.addCombinedBlock(combinedBlock);\n                    combinedBlock = null;\n                }\n\n                recalculateIndexes(this.editor.blocks);\n            }),\n            map((block) => {\n                if (block.type === COMBINED_TEXT_BLOCK_PART) {\n                    const blockData = block.data as { parentId: string };\n\n                    if (combinedBlock && blockData.parentId! !== combinedBlock?.id) {\n                        this.addCombinedBlock(combinedBlock);\n                        combinedBlock = null;\n                    }\n\n                    combinedBlock = this.setCombinedBlock(block);\n\n                    return;\n                }\n\n                if (combinedBlock) {\n                    this.addCombinedBlock(combinedBlock);\n                    combinedBlock = null;\n                }\n\n                this.addBlock(block);\n            }),\n            toArray()\n        ) as unknown as Observable<Block[]>;\n    }\n\n    private addBlock(block: Block): void {\n        if (typeof block.type !== 'string') {\n            return;\n        }\n\n        this.blockIdsMap.set(block.id!, block.id!);\n        this.insert(block);\n    }\n\n    private addCombinedBlock(combinedBlock: Block): void {\n        this.isSkipCombinedBlockOnChange.push(true);\n        const block = this.editor.blocks.getById(combinedBlock.id || '');\n\n        if (block) {\n            this.editor.blocks.update(block.id, combinedBlock.data as CuiCombinedPartBlock);\n\n            return;\n        }\n\n        this.insert(combinedBlock);\n    }\n\n    private insert(block: Block): void {\n        this.checkFirst(block);\n        this.index++;\n    }\n\n    private checkFirst(block: Block): void {\n        if (!this.isFirst) {\n            this.isSkip = true;\n            this.editor.blocks.insert(block.type, block.data, {}, this.index, false, false, block.id);\n\n            return;\n        }\n\n        // TODO: есть варик что что то пойдет не так\n        this.editor.blocks.render({ blocks: [block] }).then(() => this.isSkip = false);\n        this.isFirst = false;\n    }\n\n    private setCombinedBlock(block: Block): Block {\n        const combinedBlockData = block.data as { parentId: string };\n        const parent = this.combinedBlocks.get(combinedBlockData.parentId);\n\n        this.blockIdsMap.set(block.id!, block.id!);\n\n        if (parent) {\n            const parentData = parent.data as { textBlocks: Block[] };\n            parentData.textBlocks.push(block);\n\n            return parent;\n        }\n\n        const parentObject: Block = {\n            id: combinedBlockData.parentId,\n            type: COMBINED_TEXT_BLOCK_NAME,\n            data: {\n                id: combinedBlockData.parentId,\n                textBlocks: [block]\n            }\n        };\n\n        this.combinedBlocks.set(combinedBlockData.parentId, parentObject);\n\n        return parentObject;\n    }\n\n    private setBlockIdsToMap(blockIds: string[], addedBlocks: CuiFullBlockData[]): void {\n        if (!blockIds.length) {\n            return;\n        }\n\n        addedBlocks.forEach((blockData, index) => {\n            this.blockIdsMap.set(blockData.id, blockIds[index]);\n        });\n    }\n\n    private setStartBlock(): void {\n        if (this.blockIdsMap.size) {\n            this.setFocus();\n            this.editorEmpty.emit(this.checkIsEmpty());\n\n            return;\n        }\n\n        if (this.isReadonly()) {\n            this.editor.render({ blocks: [] });\n\n            return;\n        }\n\n        this.editorService.setStartBlock(this.editorID, async (block: Block<CuiCombinedBlockToolData>, id: string) => {\n            this.blockIdsMap.set(id, id);\n            this.isSkipCombinedBlockOnChange.push(true);\n\n            await this.editor.render({ blocks: [block] });\n\n            this.setFocus();\n            recalculateIndexes(this.editor.blocks);\n        });\n    }\n\n    private setFocus(): void {\n        if (!this.config?.autofocus) {\n            return;\n        }\n\n        this.editor.caret.focus();\n    }\n\n    private checkIsEmpty(): boolean {\n        const MIN_BLOCKS_COUNT = 1;\n        const REDACTOR_SELECTOR = '.codex-editor__redactor';\n        const redactor = this.editorElement.querySelector(REDACTOR_SELECTOR);\n        const blocksCount = redactor?.childElementCount ?? 0;\n\n        return blocksCount <= MIN_BLOCKS_COUNT && !redactor?.textContent;\n    }\n\n    private resetData(): void {\n        this.scrollSubscription?.unsubscribe();\n        this.poolingSubscription?.unsubscribe();\n        this.isSkipCombinedBlockOnChange = [];\n        this.isFirst = true;\n        this.isChanging = false;\n        this.isSkip = false;\n        this.isRequested = false;\n        this.blockIdsMap = new Map<string, string>();\n        this.combinedBlocks = new Map();\n        this.index = 0;\n        this.page = 0;\n        this.addedBlocks = [];\n        this.updatedBlocks = [];\n        this.removedBlocksIds = [];\n        this.changesQueue = [];\n        this.abortController = new AbortController();\n    }\n}\n","<div\n    #editor\n    [id]=\"editorID\"\n    [class._readonly]=\"config.readOnly\"\n    data-editor\n></div>\n"]}
391
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../projects/core/editor/editor.component.ts","../../../../projects/core/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import type { ElementRef, OnDestroy, SimpleChanges } from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    DestroyRef,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport type { CuiNullable } from '@cuby-ui/cdk';\nimport { CuiIdService } from '@cuby-ui/cdk';\nimport type { API, BlockMutationEvent, OutputData } from '@editorjs/editorjs';\nimport EditorJS from '@editorjs/editorjs';\nimport type { Observable, Subscription } from 'rxjs';\nimport {\n    concatMap,\n    delay,\n    finalize,\n    fromEvent,\n    map,\n    Subject,\n    takeWhile,\n    tap,\n    throttleTime,\n    timer,\n    toArray\n} from 'rxjs';\n\nimport { getEditorConfig } from './config';\nimport {\n    COMBINED_TEXT_BLOCK_NAME,\n    COMBINED_TEXT_BLOCK_PART,\n    DEFAULT_CONFIG\n} from './constants/editor.constants';\nimport { setEditorEvents } from './events/set-editor-events';\nimport type {\n    CuiBlockData,\n    CuiBlocksRequestData,\n    CuiCombinedBlockAddingEvent,\n    CuiCombinedBlockToolData,\n    CuiCombinedPartBlock,\n    CuiEditorConfig,\n    CuiEventActionData,\n    CuiFullBlockData\n} from './interfaces';\nimport { Block, CuiEditorService, CuiJTextApiService, EventActions } from './services';\nimport { recalculateIndexes } from './utils/recalculate-indexes';\n\n@Component({\n    selector: 'cui-editor',\n    standalone: true,\n    templateUrl: './editor.component.html',\n    styleUrls: ['./editor.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [CuiEditorService, CuiJTextApiService]\n})\nexport class CuiEditorComponent implements OnDestroy {\n    private readonly destroy = inject(DestroyRef);\n    private readonly cuiIdService = inject(CuiIdService);\n    private readonly editorService = inject(CuiEditorService);\n    private readonly jTextService = inject(CuiJTextApiService);\n\n    private readonly POOLING_DELAY = 100;\n    private readonly ELEMENT_SPACE_TO_BOTTOM = 150;\n    private readonly SCROLL_THROTTLE_TIME = 200;\n\n    private readonly isReadonly = computed(() => this.config?.readOnly);\n    private readonly emptyQueue = new Subject();\n\n    private poolingSubscription!: Subscription;\n    private scrollSubscription!: Subscription;\n    private isSkipCombinedBlockOnChange: boolean[] = [];\n    private isFirst = true;\n    private isChanging = false;\n    private isSkip = false;\n    private isRequested = false;\n    private isDestroyed = false;\n    private blockIdsMap = new Map<string, string>();\n    private combinedBlocks = new Map();\n    private index = 0;\n    private page = 0;\n    private addedBlocks: CuiBlockData[] = [];\n    private updatedBlocks: Block[] = [];\n    private removedBlocksIds: string[] = [];\n    private changesQueue: BlockMutationEvent[][] = [];\n    private abortController = new AbortController();\n\n    protected readonly editorId = this.cuiIdService.generate();\n\n    @ViewChild('editor')\n    protected readonly editorRef!: ElementRef;\n\n    @Output()\n    public readonly editorEmpty = new EventEmitter<boolean>();\n\n    @Input({ required: true })\n    public editorApiId!: string;\n\n    @Input()\n    public config: CuiEditorConfig = DEFAULT_CONFIG;\n\n    @Input()\n    public requestSize = 40;\n\n    public editor!: EditorJS;\n    public editorElement!: HTMLElement;\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes['editorApiId'] || changes['config']) {\n            this.initEditorChanges();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.isDestroyed = true;\n        this.destroyEditor();\n    }\n\n    private onScrollEvent(element: HTMLElement): void {\n        const overallHeight = element.scrollHeight - this.ELEMENT_SPACE_TO_BOTTOM;\n        const currentHeight = element.scrollTop + element.clientHeight;\n\n        if (currentHeight < overallHeight || this.isRequested) {\n            return;\n        }\n\n        this.isRequested = true;\n\n        const size = this.requestSize;\n        let blocksCount = 0;\n\n        this.getBlocks(this.page, size)\n            .pipe(\n                tap((blocks) => (blocksCount = blocks.length)),\n                finalize(() => {\n                    this.isRequested = false;\n\n                    if (blocksCount >= size) {\n                        return;\n                    }\n\n                    this.scrollSubscription.unsubscribe();\n                })\n            )\n            .subscribe();\n\n        this.page++;\n    }\n\n    private onEditorChange(_: API, event: BlockMutationEvent | BlockMutationEvent[]): void {\n        if (this.isReadonly() || this.isDestroyed) {\n            return;\n        }\n\n        if (!Array.isArray(event)) {\n            event = [event];\n        }\n\n        recalculateIndexes(this.editor.blocks);\n\n        if (this.isChanging) {\n            this.changesQueue.unshift(event);\n        }\n\n        this.startChanges(event);\n        this.editorEmpty.emit(this.checkIsEmpty());\n    }\n\n    private onAddedCombinedBlock(data: CuiCombinedBlockAddingEvent): void {\n        if (this.isSkipCombinedBlockOnChange.length) {\n            this.isSkipCombinedBlockOnChange.pop();\n\n            return;\n        }\n\n        const blocksWithoutId = data.blocks.map((block) => ({\n            block: { ...block, id: undefined },\n            id: block.id!\n        }));\n\n        this.addedBlocks.push(...blocksWithoutId);\n    }\n\n    private onUpdatedCombinedBlock(updatedBlocks: Block[]): void {\n        if (!updatedBlocks.length) {\n            return;\n        }\n\n        this.updatedBlocks.push(...updatedBlocks);\n    }\n\n    private onRemovedCombinedBlock(blockIds: string[]): void {\n        if (!blockIds.length) {\n            return;\n        }\n\n        this.removedBlocksIds.push(...blockIds);\n    }\n\n    private initEditorChanges(): void {\n        this.jTextService.addOptions(this.config.requestOptions);\n\n        this.editor = this.initEditor(this.editorId);\n        this.editor.isReady.then(() => {\n            if (this.isDestroyed) {\n                return;\n            }\n\n            this.editorElement = this.editorRef.nativeElement;\n\n            this.initEditorEvents(this.editorElement);\n            this.initScrollObserver();\n            this.startPooling(this.requestSize);\n            this.setListenersOnCustomBlockChanges();\n        });\n    }\n\n    private initEditor(id: string): EditorJS {\n        const config = this.config;\n\n        this.destroyEditor();\n        this.editor = new EditorJS({\n            ...getEditorConfig(id, config),\n            onChange: this.onEditorChange.bind(this)\n        });\n\n        return this.editor;\n    }\n\n    private initScrollObserver(): void {\n        const element = this.config?.element ?? this.editorElement;\n        const scrollObserver = fromEvent(element, 'scroll');\n\n        this.scrollSubscription = scrollObserver\n            .pipe(\n                takeUntilDestroyed(this.destroy),\n                throttleTime(this.SCROLL_THROTTLE_TIME, undefined, {\n                    leading: true,\n                    trailing: true\n                }),\n                map(() => this.onScrollEvent(element))\n            )\n            .subscribe();\n    }\n\n    private initEditorEvents(element: HTMLElement): void {\n        const readOnly = this.isReadonly();\n\n        if (readOnly) {\n            return;\n        }\n\n        setEditorEvents(element, this.abortController.signal);\n    }\n\n    private startPooling(size: number): void {\n        const scrollElement = this.config?.element ?? this.editorElement;\n        const withoutPreload = this.config?.withoutPreload;\n\n        this.poolingSubscription = timer(0, this.POOLING_DELAY)\n            .pipe(\n                concatMap(() => this.getBlocks(this.page, size).pipe(delay(this.POOLING_DELAY))),\n                tap(() => this.page++),\n                takeWhile(\n                    (blocks) =>\n                        !withoutPreload &&\n                        scrollElement.scrollHeight <= scrollElement.clientHeight &&\n                        blocks.length >= size\n                ),\n                finalize(() => {\n                    if (this.isDestroyed) {\n                        return;\n                    }\n\n                    this.setStartBlock();\n                })\n            )\n            .subscribe();\n    }\n\n    private destroyEditor(): void {\n        this.abortController.abort();\n        this.resetData();\n        // TODO: в рандом кейсах падает ошибка если убрать проверку на вызов destroy\n        this.editor?.destroy?.();\n    }\n\n    private setListenersOnCustomBlockChanges(): void {\n        this.editorService.setListenersOnCustomBlockChanges(this.editor, {\n            removedCallback: this.onRemovedCombinedBlock.bind(this),\n            updatedCallback: this.onUpdatedCombinedBlock.bind(this),\n            addedCallback: this.onAddedCombinedBlock.bind(this)\n        });\n    }\n\n    private async startChanges(event: BlockMutationEvent[]): Promise<void> {\n        if (this.isSkip || this.isChanging) {\n            this.isSkip = false;\n\n            return;\n        }\n\n        this.isChanging = true;\n\n        try {\n            const editorOutput = await this.editor.save();\n            const events = event.filter((data) => data.detail.target.name !== COMBINED_TEXT_BLOCK_NAME);\n            const blocks = this.editorService.sortEventsByTypes(events);\n            const { addBlocks$, addedBlocks } = this.collectAddedBlocksRequest(blocks, editorOutput);\n\n            this.addedBlocks = [];\n\n            addBlocks$\n                .pipe(\n                    tap((blockIds) => this.setBlockIdsToMap(blockIds, addedBlocks)),\n                    concatMap(() => this.collectUpdatedBlocksRequest(blocks, editorOutput)),\n                    concatMap(() => this.collectRemovedBlocksRequest(blocks))\n                )\n                .subscribe({\n                    complete: () => this.startNextChange(),\n                    error: () => this.startNextChange()\n                });\n        } catch (e) {\n            return;\n        }\n    }\n\n    private startNextChange(): void {\n        this.isChanging = false;\n\n        const nextEvents = this.changesQueue.pop();\n\n        if (nextEvents) {\n            this.startChanges(nextEvents);\n        }\n\n        this.emptyQueue.next(null);\n    }\n\n    private collectAddedBlocksRequest(blocks: CuiEventActionData, editorOutput: OutputData): CuiBlocksRequestData {\n        const defaultBlocksWithIndex = blocks[EventActions.add].map((addedBlock) =>\n            this.editorService.getFullBlockData(addedBlock, editorOutput)\n        );\n        const combinedBlocksWithIndex = this.addedBlocks.map((block) => {\n            const element = this.editorElement.querySelector(`[data-id=\"${block.id}\"]`) as HTMLElement;\n            const index = Number(element?.dataset['index']);\n\n            return { ...block, index };\n        });\n\n        const addedBlocks = [...defaultBlocksWithIndex, ...combinedBlocksWithIndex].sort((first, second) => first.index - second.index);\n        const addBlocks$ = this.editorService.collectAddedBlocksRequest(this.editorApiId, addedBlocks);\n\n        return {\n            addedBlocks,\n            addBlocks$\n        };\n    }\n\n    private collectUpdatedBlocksRequest(blocks: CuiEventActionData, editorOutput: OutputData): Observable<Block[]> {\n        blocks[EventActions.update].forEach((updateBlock) => {\n            const { id, block } = this.editorService.getFullBlockData(updateBlock, editorOutput);\n            block.id = id;\n\n            this.updatedBlocks.push(block);\n        });\n\n        const updateBlocks$ = this.editorService.collectUpdatedBlocksRequest(this.updatedBlocks, this.blockIdsMap);\n\n        this.updatedBlocks = [];\n\n        return updateBlocks$;\n    }\n\n    private collectRemovedBlocksRequest(blocks: CuiEventActionData): Observable<void> {\n        blocks[EventActions.remove].forEach((block) => {\n            const id = block.detail.target.id;\n\n            this.removedBlocksIds.push(id);\n        });\n\n        const removeBlocks$ = this.editorService.collectRemovedBlocksRequest(\n            this.editorApiId,\n            this.removedBlocksIds,\n            this.blockIdsMap\n        );\n        this.removedBlocksIds = [];\n\n        return removeBlocks$;\n    }\n\n    private getBlocks(page = 0, size = 40): Observable<Block[]> {\n        let combinedBlock: CuiNullable<Block>;\n\n        return this.jTextService.getBlocks(this.editorApiId, page, size).pipe(\n            takeUntilDestroyed(this.destroy),\n            finalize(() => {\n                if (combinedBlock) {\n                    this.addCombinedBlock(combinedBlock);\n                    combinedBlock = null;\n                }\n\n                recalculateIndexes(this.editor.blocks);\n            }),\n            map((block) => {\n                if (block.type === COMBINED_TEXT_BLOCK_PART) {\n                    const blockData = block.data as { parentId: string };\n\n                    if (combinedBlock && blockData.parentId! !== combinedBlock?.id) {\n                        this.addCombinedBlock(combinedBlock);\n                        combinedBlock = null;\n                    }\n\n                    combinedBlock = this.setCombinedBlock(block);\n\n                    return;\n                }\n\n                if (combinedBlock) {\n                    this.addCombinedBlock(combinedBlock);\n                    combinedBlock = null;\n                }\n\n                this.addBlock(block);\n            }),\n            toArray()\n        ) as unknown as Observable<Block[]>;\n    }\n\n    private addBlock(block: Block): void {\n        if (typeof block.type !== 'string') {\n            return;\n        }\n\n        this.blockIdsMap.set(block.id!, block.id!);\n        this.insert(block);\n    }\n\n    private addCombinedBlock(combinedBlock: Block): void {\n        this.isSkipCombinedBlockOnChange.push(true);\n        const block = this.editor.blocks.getById(combinedBlock.id || '');\n\n        if (block) {\n            this.editor.blocks.update(block.id, combinedBlock.data as CuiCombinedPartBlock);\n\n            return;\n        }\n\n        this.insert(combinedBlock);\n    }\n\n    private insert(block: Block): void {\n        this.checkFirst(block);\n        this.index++;\n    }\n\n    private checkFirst(block: Block): void {\n        if (!this.isFirst) {\n            this.isSkip = true;\n            this.editor.blocks.insert(block.type, block.data, {}, this.index, false, false, block.id);\n\n            return;\n        }\n\n        // TODO: есть варик что что то пойдет не так\n        this.editor.blocks.render({ blocks: [block] }).then(() => this.isSkip = false);\n        this.isFirst = false;\n    }\n\n    private setCombinedBlock(block: Block): Block {\n        const combinedBlockData = block.data as { parentId: string };\n        const parent = this.combinedBlocks.get(combinedBlockData.parentId);\n\n        this.blockIdsMap.set(block.id!, block.id!);\n\n        if (parent) {\n            const parentData = parent.data as { textBlocks: Block[] };\n            parentData.textBlocks.push(block);\n\n            return parent;\n        }\n\n        const parentObject: Block = {\n            id: combinedBlockData.parentId,\n            type: COMBINED_TEXT_BLOCK_NAME,\n            data: {\n                id: combinedBlockData.parentId,\n                textBlocks: [block]\n            }\n        };\n\n        this.combinedBlocks.set(combinedBlockData.parentId, parentObject);\n\n        return parentObject;\n    }\n\n    private setBlockIdsToMap(blockIds: string[], addedBlocks: CuiFullBlockData[]): void {\n        if (!blockIds.length) {\n            return;\n        }\n\n        addedBlocks.forEach((blockData, index) => {\n            this.blockIdsMap.set(blockData.id, blockIds[index]);\n        });\n    }\n\n    private setStartBlock(): void {\n        if (this.blockIdsMap.size) {\n            this.setFocus();\n            this.editorEmpty.emit(this.checkIsEmpty());\n\n            return;\n        }\n\n        if (this.isReadonly()) {\n            this.editor.render({ blocks: [] });\n\n            return;\n        }\n\n        this.editorService.setStartBlock(this.editorApiId, async (block: Block<CuiCombinedBlockToolData>, id: string) => {\n            this.blockIdsMap.set(id, id);\n            this.isSkipCombinedBlockOnChange.push(true);\n\n            await this.editor.render({ blocks: [block] });\n\n            this.setFocus();\n            recalculateIndexes(this.editor.blocks);\n        });\n    }\n\n    private setFocus(): void {\n        if (!this.config?.autofocus) {\n            return;\n        }\n\n        this.editor.caret.focus();\n    }\n\n    private checkIsEmpty(): boolean {\n        const MIN_BLOCKS_COUNT = 1;\n        const REDACTOR_SELECTOR = '.codex-editor__redactor';\n        const redactor = this.editorElement.querySelector(REDACTOR_SELECTOR);\n        const blocksCount = redactor?.childElementCount ?? 0;\n\n        return blocksCount <= MIN_BLOCKS_COUNT && !redactor?.textContent;\n    }\n\n    private resetData(): void {\n        this.scrollSubscription?.unsubscribe();\n        this.poolingSubscription?.unsubscribe();\n        this.isSkipCombinedBlockOnChange = [];\n        this.isFirst = true;\n        this.isChanging = false;\n        this.isSkip = false;\n        this.isRequested = false;\n        this.blockIdsMap = new Map<string, string>();\n        this.combinedBlocks = new Map();\n        this.index = 0;\n        this.page = 0;\n        this.addedBlocks = [];\n        this.updatedBlocks = [];\n        this.removedBlocksIds = [];\n        this.changesQueue = [];\n        this.abortController = new AbortController();\n    }\n}\n","<div\n    #editor\n    [id]=\"editorId\"\n    data-editor\n    [class._readonly]=\"config.readOnly\"\n></div>\n"]}
@@ -1,6 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, effect, ElementRef, input, output, signal, viewChild } from '@angular/core';
2
2
  import { TranslocoDirective } from '@jsverse/transloco';
3
- import { CuiButtonModule, CuiHintModule, CuiContentWrapperComponent } from '../../../components';
3
+ import { CuiButtonModule, CuiContentWrapperComponent, CuiHintModule } from '../../../components';
4
4
  import { CuiTooltip } from '../../../directives';
5
5
  import { CuiEditorComponent } from '../../editor.component';
6
6
  import { CuiEditorModalComponent } from '../editor-modal/editor-modal.component';
@@ -46,7 +46,7 @@ export class CuiEditorBlockComponent {
46
46
  }, { allowSignalWrites: true });
47
47
  }
48
48
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiEditorBlockComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
49
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiEditorBlockComponent, isStandalone: true, selector: "cui-editor-block", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, editorId: { classPropertyName: "editorId", publicName: "editorId", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { editorEmpty: "editorEmpty" }, viewQueries: [{ propertyName: "editorContainer", first: true, predicate: ["editorContainer"], descendants: true, read: ElementRef, isSignal: true }], ngImport: i0, template: "<ng-container *transloco=\"let t\">\n <div class=\"wrapper\">\n <span class=\"title\">\n {{ t('DESCRIPTION') }}\n @if (required()) {\n <span class=\"title__required\">*</span>\n }\n </span>\n <ng-template #button>\n <button\n [cuiTooltip]=\"t('EXPAND_EDITOR_TO_FULLSCREEN')\"\n cuiButton\n size=\"xxs\"\n type=\"button\"\n appearance=\"ghost\"\n icon=\"cuiIconMaximizeSm\"\n (click)=\"onToggleDescriptionModal()\"\n ></button>\n </ng-template>\n <cui-editor-modal\n [title]=\"title()\"\n [editorId]=\"editorId()\"\n [buttonTemplate]=\"button\"\n [config]=\"config()\"\n (modalClosed)=\"onToggleDescriptionModal()\"\n />\n </div>\n <div\n #editorContainer\n cuiContentWrapper\n class=\"editor\"\n [class.editor_invalid]=\"required() && isDescriptionEmpty()\"\n >\n @if (!isDescriptionModalOpen() && editorConfig()) {\n <cui-editor\n #editorComponent\n [editorID]=\"editorId()\"\n [config]=\"editorConfig()!\"\n (editorEmpty)=\"onDescriptionChange($event)\"\n />\n }\n </div>\n @if (required() && isDescriptionEmpty()) {\n <cui-hint hintType=\"error\">{{ t('DESCRIPTION_IS_REQUIRED') }}</cui-hint>\n }\n</ng-container>\n", styles: [":host{--max-editor-height: 650px;padding:16px;display:flex;flex-direction:column;gap:8px;background:var(--cui-base-10);border-radius:8px}:host .editor{max-height:var(--max-editor-height)}.wrapper{display:flex;gap:8px;align-items:center;justify-content:space-between}.editor{padding-top:16px;padding-bottom:16px;display:block;overflow:auto}.editor_invalid{border:1px solid var(--cui-danger)}.title{font-weight:500;font-size:14px;line-height:20px}.title__required{color:var(--cui-danger)}\n"], dependencies: [{ kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i1.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "size"] }, { kind: "component", type: CuiEditorModalComponent, selector: "cui-editor-modal", inputs: ["title", "buttonTemplate", "config", "editorId"], outputs: ["editorCreated", "modalClosed"] }, { kind: "component", type: CuiEditorComponent, selector: "cui-editor", inputs: ["editorID", "config", "requestSize"], outputs: ["editorEmpty"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: CuiContentWrapperComponent, selector: "cui-content-wrapper, [cuiContentWrapper]", inputs: ["backgroundColor", "gap"] }, { kind: "directive", type: i2.CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }, { kind: "ngmodule", type: CuiHintModule }, { kind: "component", type: i3.CuiHintComponent, selector: "cui-hint", inputs: ["hintType"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
49
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiEditorBlockComponent, isStandalone: true, selector: "cui-editor-block", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, editorId: { classPropertyName: "editorId", publicName: "editorId", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { editorEmpty: "editorEmpty" }, viewQueries: [{ propertyName: "editorContainer", first: true, predicate: ["editorContainer"], descendants: true, read: ElementRef, isSignal: true }], ngImport: i0, template: "<ng-container *transloco=\"let t\">\n <div class=\"wrapper\">\n <span class=\"title\">\n {{ t('DESCRIPTION') }}\n @if (required()) {\n <span class=\"title__required\">*</span>\n }\n </span>\n <ng-template #button>\n <button\n [cuiTooltip]=\"t('EXPAND_EDITOR_TO_FULLSCREEN')\"\n cuiButton\n size=\"xxs\"\n type=\"button\"\n appearance=\"ghost\"\n icon=\"cuiIconMaximizeSm\"\n (click)=\"onToggleDescriptionModal()\"\n ></button>\n </ng-template>\n <cui-editor-modal\n [title]=\"title()\"\n [editorId]=\"editorId()\"\n [buttonTemplate]=\"button\"\n [config]=\"config()\"\n (modalClosed)=\"onToggleDescriptionModal()\"\n />\n </div>\n <div\n #editorContainer\n cuiContentWrapper\n class=\"editor\"\n [class.editor_invalid]=\"required() && isDescriptionEmpty()\"\n >\n @if (!isDescriptionModalOpen() && editorConfig()) {\n <cui-editor\n #editorComponent\n [editorApiId]=\"editorId()\"\n [config]=\"editorConfig()!\"\n (editorEmpty)=\"onDescriptionChange($event)\"\n />\n }\n </div>\n @if (required() && isDescriptionEmpty()) {\n <cui-hint hintType=\"error\">{{ t('DESCRIPTION_IS_REQUIRED') }}</cui-hint>\n }\n</ng-container>\n", styles: [":host{--max-editor-height: 650px;padding:16px;display:flex;flex-direction:column;gap:8px;background:var(--cui-base-10);border-radius:8px}:host .editor{max-height:var(--max-editor-height)}.wrapper{display:flex;gap:8px;align-items:center;justify-content:space-between}.editor{padding-top:16px;padding-bottom:16px;display:block;overflow:auto}.editor_invalid{border:1px solid var(--cui-danger)}.title{font-weight:500;font-size:14px;line-height:20px}.title__required{color:var(--cui-danger)}\n"], dependencies: [{ kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i1.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "size"] }, { kind: "component", type: CuiEditorModalComponent, selector: "cui-editor-modal", inputs: ["title", "buttonTemplate", "config", "editorId"], outputs: ["editorCreated", "modalClosed"] }, { kind: "component", type: CuiEditorComponent, selector: "cui-editor", inputs: ["editorApiId", "config", "requestSize"], outputs: ["editorEmpty"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: CuiContentWrapperComponent, selector: "cui-content-wrapper, [cuiContentWrapper]", inputs: ["backgroundColor", "gap"] }, { kind: "directive", type: i2.CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }, { kind: "ngmodule", type: CuiHintModule }, { kind: "component", type: i3.CuiHintComponent, selector: "cui-hint", inputs: ["hintType"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
50
50
  }
51
51
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiEditorBlockComponent, decorators: [{
52
52
  type: Component,
@@ -58,6 +58,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
58
58
  CuiContentWrapperComponent,
59
59
  CuiTooltip,
60
60
  CuiHintModule
61
- ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\n <div class=\"wrapper\">\n <span class=\"title\">\n {{ t('DESCRIPTION') }}\n @if (required()) {\n <span class=\"title__required\">*</span>\n }\n </span>\n <ng-template #button>\n <button\n [cuiTooltip]=\"t('EXPAND_EDITOR_TO_FULLSCREEN')\"\n cuiButton\n size=\"xxs\"\n type=\"button\"\n appearance=\"ghost\"\n icon=\"cuiIconMaximizeSm\"\n (click)=\"onToggleDescriptionModal()\"\n ></button>\n </ng-template>\n <cui-editor-modal\n [title]=\"title()\"\n [editorId]=\"editorId()\"\n [buttonTemplate]=\"button\"\n [config]=\"config()\"\n (modalClosed)=\"onToggleDescriptionModal()\"\n />\n </div>\n <div\n #editorContainer\n cuiContentWrapper\n class=\"editor\"\n [class.editor_invalid]=\"required() && isDescriptionEmpty()\"\n >\n @if (!isDescriptionModalOpen() && editorConfig()) {\n <cui-editor\n #editorComponent\n [editorID]=\"editorId()\"\n [config]=\"editorConfig()!\"\n (editorEmpty)=\"onDescriptionChange($event)\"\n />\n }\n </div>\n @if (required() && isDescriptionEmpty()) {\n <cui-hint hintType=\"error\">{{ t('DESCRIPTION_IS_REQUIRED') }}</cui-hint>\n }\n</ng-container>\n", styles: [":host{--max-editor-height: 650px;padding:16px;display:flex;flex-direction:column;gap:8px;background:var(--cui-base-10);border-radius:8px}:host .editor{max-height:var(--max-editor-height)}.wrapper{display:flex;gap:8px;align-items:center;justify-content:space-between}.editor{padding-top:16px;padding-bottom:16px;display:block;overflow:auto}.editor_invalid{border:1px solid var(--cui-danger)}.title{font-weight:500;font-size:14px;line-height:20px}.title__required{color:var(--cui-danger)}\n"] }]
61
+ ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\n <div class=\"wrapper\">\n <span class=\"title\">\n {{ t('DESCRIPTION') }}\n @if (required()) {\n <span class=\"title__required\">*</span>\n }\n </span>\n <ng-template #button>\n <button\n [cuiTooltip]=\"t('EXPAND_EDITOR_TO_FULLSCREEN')\"\n cuiButton\n size=\"xxs\"\n type=\"button\"\n appearance=\"ghost\"\n icon=\"cuiIconMaximizeSm\"\n (click)=\"onToggleDescriptionModal()\"\n ></button>\n </ng-template>\n <cui-editor-modal\n [title]=\"title()\"\n [editorId]=\"editorId()\"\n [buttonTemplate]=\"button\"\n [config]=\"config()\"\n (modalClosed)=\"onToggleDescriptionModal()\"\n />\n </div>\n <div\n #editorContainer\n cuiContentWrapper\n class=\"editor\"\n [class.editor_invalid]=\"required() && isDescriptionEmpty()\"\n >\n @if (!isDescriptionModalOpen() && editorConfig()) {\n <cui-editor\n #editorComponent\n [editorApiId]=\"editorId()\"\n [config]=\"editorConfig()!\"\n (editorEmpty)=\"onDescriptionChange($event)\"\n />\n }\n </div>\n @if (required() && isDescriptionEmpty()) {\n <cui-hint hintType=\"error\">{{ t('DESCRIPTION_IS_REQUIRED') }}</cui-hint>\n }\n</ng-container>\n", styles: [":host{--max-editor-height: 650px;padding:16px;display:flex;flex-direction:column;gap:8px;background:var(--cui-base-10);border-radius:8px}:host .editor{max-height:var(--max-editor-height)}.wrapper{display:flex;gap:8px;align-items:center;justify-content:space-between}.editor{padding-top:16px;padding-bottom:16px;display:block;overflow:auto}.editor_invalid{border:1px solid var(--cui-danger)}.title{font-weight:500;font-size:14px;line-height:20px}.title__required{color:var(--cui-danger)}\n"] }]
62
62
  }], ctorParameters: () => [] });
63
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-block.component.js","sourceRoot":"","sources":["../../../../../../projects/core/editor/widgets/editor-block/editor-block.component.ts","../../../../../../projects/core/editor/widgets/editor-block/editor-block.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,MAAM,EACN,UAAU,EACV,KAAK,EACL,MAAM,EACN,MAAM,EACN,SAAS,EACZ,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAExD,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,0BAA0B,EAAE,MAAM,qBAAqB,CAAC;AACjG,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAGjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,uBAAuB,EAAE,MAAM,wCAAwC,CAAC;;;;;AAkBjF,MAAM,OAAO,uBAAuB;IAkBhC;QAjBQ,wBAAmB,GAAG,IAAI,CAAC;QAEhB,iBAAY,GAAG,MAAM,CAA+B,IAAI,CAAC,CAAC;QAC1D,2BAAsB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACvC,uBAAkB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAEtC,oBAAe,GAAG,SAAS,CAAkC,iBAAiB,EAAE;YAC5F,IAAI,EAAE,UAAU;SACnB,CAAC,CAAC;QAEa,UAAK,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;QACjC,aAAQ,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;QACpC,WAAM,GAAG,KAAK,CAAC,QAAQ,EAAmB,CAAC;QAC3C,aAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAExB,gBAAW,GAAG,MAAM,EAAW,CAAC;QAG5C,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAES,wBAAwB;QAC9B,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;IACxD,CAAC;IAES,mBAAmB,CAAC,KAAc;QACxC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE7B,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;YAEjC,OAAO;QACX,CAAC;QAED,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAEO,gBAAgB;QACpB,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,EAAE;YAC1B,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,EAAE,aAAa,CAAC;YAEtD,IAAI,CAAC,OAAO,EAAE,CAAC;gBACX,OAAO;YACX,CAAC;YAED,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YACrD,SAAS,CAAC,OAAO,EAAE,CAAC;QACxB,CAAC,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,CAAC;IACpC,CAAC;+GAjDQ,uBAAuB;mGAAvB,uBAAuB,ktBAQtB,UAAU,6CC5CxB,wgDA8CA,iiBDvBQ,eAAe,2NACf,uBAAuB,mKACvB,kBAAkB,gIAClB,kBAAkB,gMAClB,0BAA0B,+SAE1B,aAAa;;4FAOR,uBAAuB;kBAhBnC,SAAS;+BACI,kBAAkB,WACnB;wBACL,eAAe;wBACf,uBAAuB;wBACvB,kBAAkB;wBAClB,kBAAkB;wBAClB,0BAA0B;wBAC1B,UAAU;wBACV,aAAa;qBAChB,cACW,IAAI,mBAGC,uBAAuB,CAAC,MAAM","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    effect,\n    ElementRef,\n    input,\n    output,\n    signal,\n    viewChild\n} from '@angular/core';\nimport type { CuiNullable } from '@cuby-ui/cdk';\nimport { TranslocoDirective } from '@jsverse/transloco';\n\nimport { CuiButtonModule, CuiHintModule, CuiContentWrapperComponent } from '../../../components';\nimport { CuiTooltip } from '../../../directives';\n\nimport type { CuiEditorConfig } from '../../interfaces';\nimport { CuiEditorComponent } from '../../editor.component';\nimport { CuiEditorModalComponent } from '../editor-modal/editor-modal.component';\n\n@Component({\n    selector: 'cui-editor-block',\n    imports: [\n        CuiButtonModule,\n        CuiEditorModalComponent,\n        CuiEditorComponent,\n        TranslocoDirective,\n        CuiContentWrapperComponent,\n        CuiTooltip,\n        CuiHintModule\n    ],\n    standalone: true,\n    templateUrl: './editor-block.component.html',\n    styleUrls: ['./editor-block.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiEditorBlockComponent {\n    private skipFirstValidation = true;\n\n    protected readonly editorConfig = signal<CuiNullable<CuiEditorConfig>>(null);\n    protected readonly isDescriptionModalOpen = signal(false);\n    protected readonly isDescriptionEmpty = signal(false);\n\n    public readonly editorContainer = viewChild<string, ElementRef<HTMLElement>>('editorContainer', {\n        read: ElementRef\n    });\n\n    public readonly title = input.required<string>();\n    public readonly editorId = input.required<string>();\n    public readonly config = input.required<CuiEditorConfig>();\n    public readonly required = input(false);\n\n    public readonly editorEmpty = output<boolean>();\n\n    constructor() {\n        this.initEditorConfig();\n    }\n\n    protected onToggleDescriptionModal(): void {\n        this.isDescriptionModalOpen.update((prev) => !prev);\n    }\n\n    protected onDescriptionChange(value: boolean): void {\n        this.editorEmpty.emit(value);\n\n        if (this.skipFirstValidation) {\n            this.skipFirstValidation = false;\n\n            return;\n        }\n\n        this.isDescriptionEmpty.set(value);\n    }\n\n    private initEditorConfig(): void {\n        const effectRef = effect(() => {\n            const element = this.editorContainer()?.nativeElement;\n\n            if (!element) {\n                return;\n            }\n\n            this.editorConfig.set({ element, ...this.config() });\n            effectRef.destroy();\n        }, { allowSignalWrites: true });\n    }\n}\n","<ng-container *transloco=\"let t\">\n    <div class=\"wrapper\">\n        <span class=\"title\">\n            {{ t('DESCRIPTION') }}\n            @if (required()) {\n                <span class=\"title__required\">*</span>\n            }\n        </span>\n        <ng-template #button>\n            <button\n                [cuiTooltip]=\"t('EXPAND_EDITOR_TO_FULLSCREEN')\"\n                cuiButton\n                size=\"xxs\"\n                type=\"button\"\n                appearance=\"ghost\"\n                icon=\"cuiIconMaximizeSm\"\n                (click)=\"onToggleDescriptionModal()\"\n            ></button>\n        </ng-template>\n        <cui-editor-modal\n            [title]=\"title()\"\n            [editorId]=\"editorId()\"\n            [buttonTemplate]=\"button\"\n            [config]=\"config()\"\n            (modalClosed)=\"onToggleDescriptionModal()\"\n        />\n    </div>\n    <div\n        #editorContainer\n        cuiContentWrapper\n        class=\"editor\"\n        [class.editor_invalid]=\"required() && isDescriptionEmpty()\"\n    >\n        @if (!isDescriptionModalOpen() && editorConfig()) {\n            <cui-editor\n                #editorComponent\n                [editorID]=\"editorId()\"\n                [config]=\"editorConfig()!\"\n                (editorEmpty)=\"onDescriptionChange($event)\"\n            />\n        }\n    </div>\n    @if (required() && isDescriptionEmpty()) {\n        <cui-hint hintType=\"error\">{{ t('DESCRIPTION_IS_REQUIRED') }}</cui-hint>\n    }\n</ng-container>\n"]}
63
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-block.component.js","sourceRoot":"","sources":["../../../../../../projects/core/editor/widgets/editor-block/editor-block.component.ts","../../../../../../projects/core/editor/widgets/editor-block/editor-block.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,MAAM,EACN,UAAU,EACV,KAAK,EACL,MAAM,EACN,MAAM,EACN,SAAS,EACZ,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAExD,OAAO,EAAE,eAAe,EAAE,0BAA0B,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACjG,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAE5D,OAAO,EAAE,uBAAuB,EAAE,MAAM,wCAAwC,CAAC;;;;;AAkBjF,MAAM,OAAO,uBAAuB;IAkBhC;QAjBQ,wBAAmB,GAAG,IAAI,CAAC;QAEhB,iBAAY,GAAG,MAAM,CAA+B,IAAI,CAAC,CAAC;QAC1D,2BAAsB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACvC,uBAAkB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAEtC,oBAAe,GAAG,SAAS,CAAkC,iBAAiB,EAAE;YAC5F,IAAI,EAAE,UAAU;SACnB,CAAC,CAAC;QAEa,UAAK,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;QACjC,aAAQ,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;QACpC,WAAM,GAAG,KAAK,CAAC,QAAQ,EAAmB,CAAC;QAC3C,aAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAExB,gBAAW,GAAG,MAAM,EAAW,CAAC;QAG5C,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAES,wBAAwB;QAC9B,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;IACxD,CAAC;IAES,mBAAmB,CAAC,KAAc;QACxC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE7B,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;YAEjC,OAAO;QACX,CAAC;QAED,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAEO,gBAAgB;QACpB,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,EAAE;YAC1B,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,EAAE,aAAa,CAAC;YAEtD,IAAI,CAAC,OAAO,EAAE,CAAC;gBACX,OAAO;YACX,CAAC;YAED,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YACrD,SAAS,CAAC,OAAO,EAAE,CAAC;QACxB,CAAC,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,CAAC;IACpC,CAAC;+GAjDQ,uBAAuB;mGAAvB,uBAAuB,ktBAQtB,UAAU,6CC5CxB,2gDA8CA,iiBDvBQ,eAAe,2NACf,uBAAuB,mKACvB,kBAAkB,mIAClB,kBAAkB,gMAClB,0BAA0B,+SAE1B,aAAa;;4FAOR,uBAAuB;kBAhBnC,SAAS;+BACI,kBAAkB,WACnB;wBACL,eAAe;wBACf,uBAAuB;wBACvB,kBAAkB;wBAClB,kBAAkB;wBAClB,0BAA0B;wBAC1B,UAAU;wBACV,aAAa;qBAChB,cACW,IAAI,mBAGC,uBAAuB,CAAC,MAAM","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    effect,\n    ElementRef,\n    input,\n    output,\n    signal,\n    viewChild\n} from '@angular/core';\nimport type { CuiNullable } from '@cuby-ui/cdk';\nimport { TranslocoDirective } from '@jsverse/transloco';\n\nimport { CuiButtonModule, CuiContentWrapperComponent, CuiHintModule } from '../../../components';\nimport { CuiTooltip } from '../../../directives';\n\nimport { CuiEditorComponent } from '../../editor.component';\nimport type { CuiEditorConfig } from '../../interfaces';\nimport { CuiEditorModalComponent } from '../editor-modal/editor-modal.component';\n\n@Component({\n    selector: 'cui-editor-block',\n    imports: [\n        CuiButtonModule,\n        CuiEditorModalComponent,\n        CuiEditorComponent,\n        TranslocoDirective,\n        CuiContentWrapperComponent,\n        CuiTooltip,\n        CuiHintModule\n    ],\n    standalone: true,\n    templateUrl: './editor-block.component.html',\n    styleUrls: ['./editor-block.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiEditorBlockComponent {\n    private skipFirstValidation = true;\n\n    protected readonly editorConfig = signal<CuiNullable<CuiEditorConfig>>(null);\n    protected readonly isDescriptionModalOpen = signal(false);\n    protected readonly isDescriptionEmpty = signal(false);\n\n    public readonly editorContainer = viewChild<string, ElementRef<HTMLElement>>('editorContainer', {\n        read: ElementRef\n    });\n\n    public readonly title = input.required<string>();\n    public readonly editorId = input.required<string>();\n    public readonly config = input.required<CuiEditorConfig>();\n    public readonly required = input(false);\n\n    public readonly editorEmpty = output<boolean>();\n\n    constructor() {\n        this.initEditorConfig();\n    }\n\n    protected onToggleDescriptionModal(): void {\n        this.isDescriptionModalOpen.update((prev) => !prev);\n    }\n\n    protected onDescriptionChange(value: boolean): void {\n        this.editorEmpty.emit(value);\n\n        if (this.skipFirstValidation) {\n            this.skipFirstValidation = false;\n\n            return;\n        }\n\n        this.isDescriptionEmpty.set(value);\n    }\n\n    private initEditorConfig(): void {\n        const effectRef = effect(() => {\n            const element = this.editorContainer()?.nativeElement;\n\n            if (!element) {\n                return;\n            }\n\n            this.editorConfig.set({ element, ...this.config() });\n            effectRef.destroy();\n        }, { allowSignalWrites: true });\n    }\n}\n","<ng-container *transloco=\"let t\">\n    <div class=\"wrapper\">\n        <span class=\"title\">\n            {{ t('DESCRIPTION') }}\n            @if (required()) {\n                <span class=\"title__required\">*</span>\n            }\n        </span>\n        <ng-template #button>\n            <button\n                [cuiTooltip]=\"t('EXPAND_EDITOR_TO_FULLSCREEN')\"\n                cuiButton\n                size=\"xxs\"\n                type=\"button\"\n                appearance=\"ghost\"\n                icon=\"cuiIconMaximizeSm\"\n                (click)=\"onToggleDescriptionModal()\"\n            ></button>\n        </ng-template>\n        <cui-editor-modal\n            [title]=\"title()\"\n            [editorId]=\"editorId()\"\n            [buttonTemplate]=\"button\"\n            [config]=\"config()\"\n            (modalClosed)=\"onToggleDescriptionModal()\"\n        />\n    </div>\n    <div\n        #editorContainer\n        cuiContentWrapper\n        class=\"editor\"\n        [class.editor_invalid]=\"required() && isDescriptionEmpty()\"\n    >\n        @if (!isDescriptionModalOpen() && editorConfig()) {\n            <cui-editor\n                #editorComponent\n                [editorApiId]=\"editorId()\"\n                [config]=\"editorConfig()!\"\n                (editorEmpty)=\"onDescriptionChange($event)\"\n            />\n        }\n    </div>\n    @if (required() && isDescriptionEmpty()) {\n        <cui-hint hintType=\"error\">{{ t('DESCRIPTION_IS_REQUIRED') }}</cui-hint>\n    }\n</ng-container>\n"]}
@@ -33,7 +33,7 @@ export class CuiEditorModalComponent {
33
33
  this.modalClosed.emit();
34
34
  }
35
35
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiEditorModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
36
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiEditorModalComponent, isStandalone: true, selector: "cui-editor-modal", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, buttonTemplate: { classPropertyName: "buttonTemplate", publicName: "buttonTemplate", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, editorId: { classPropertyName: "editorId", publicName: "editorId", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { editorCreated: "editorCreated", modalClosed: "modalClosed" }, ngImport: i0, template: "@if (buttonTemplate(); as template) {\n <button\n type=\"button\"\n class=\"button\"\n (click)=\"onModalOpen()\"\n >\n <ng-container [ngTemplateOutlet]=\"template\" />\n </button>\n} @else {\n <button\n class=\"description\"\n cuiButton\n type=\"button\"\n appearance=\"outlined-gray\"\n icon=\"cuiIconRichText\"\n size=\"sm\"\n (click)=\"onModalOpen()\"\n [disabled]=\"isButtonDisabled()\"\n >\n @if (editorId()) {\n <span class=\"description__text _created\">{{ 'Description' }}</span>\n <cui-svg\n class=\"description__icon\"\n icon=\"cuiIconEdit\"\n color=\"var(--cui-base-500)\"\n />\n } @else {\n <cui-svg\n class=\"description__icon\"\n icon=\"cuiIconPlus\"\n color=\"var(--cui-light-blue-600)\"\n />\n <span class=\"description__text\">{{ 'Add description' }}</span>\n }\n </button>\n}\n@if (isOpen()) {\n <div class=\"wrapper\">\n @if (editorId(); as id) {\n <header class=\"header\">\n <div class=\"info\">\n <button\n cuiButton\n type=\"button\"\n icon=\"cuiIconChevronLeft\"\n size=\"xxs\"\n appearance=\"secondary\"\n shape=\"rounded\"\n (click)=\"close()\"\n ></button>\n <h1 class=\"title\">{{ title() }}</h1>\n </div>\n <div class=\"actions\">\n <!-- <cui-loader /> -->\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n (click)=\"close()\"\n >\n {{ 'Done' }}\n </button>\n </div>\n </header>\n\n <section class=\"section\">\n <cui-editor\n #editorComponent\n class=\"editor\"\n [editorID]=\"id\"\n [config]=\"config()\"\n />\n </section>\n }\n </div>\n}\n", styles: [":host ::ng-deep .delete{width:max-content}:host ::ng-deep .delete .c-content{display:flex;align-items:center;gap:4px;color:var(--cui-danger)}:host ::ng-deep .description .c-content{display:flex;align-items:center;gap:4px}.button{padding:0}.description{width:max-content}.description__text{color:var(--cui-light-blue-600)}.description__text._created{color:var(--cui-base-900)}.description__icon{padding:4px}.wrapper{position:fixed;z-index:10;inset:0;background-color:var(--cui-base-0)}.header{display:flex;justify-content:space-between;padding:8px 16px;border-bottom:.5px solid var(--cui-base-200);background:var(--cui-base-0)}.info,.actions{display:flex;gap:12px;align-items:center}.section{padding-right:24px;padding-left:24px;padding-top:24px;height:calc(100% - 50px);overflow:hidden}.title{font-weight:500;font-size:14px;line-height:20px;margin:0}.editor{padding-right:32px;padding-left:32px;padding-top:32px;display:block;margin:0 auto;max-width:750px;height:100%}\n"], dependencies: [{ kind: "component", type: CuiEditorComponent, selector: "cui-editor", inputs: ["editorID", "config", "requestSize"], outputs: ["editorEmpty"] }, { kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i1.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "size"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i2.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }] }); }
36
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiEditorModalComponent, isStandalone: true, selector: "cui-editor-modal", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, buttonTemplate: { classPropertyName: "buttonTemplate", publicName: "buttonTemplate", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, editorId: { classPropertyName: "editorId", publicName: "editorId", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { editorCreated: "editorCreated", modalClosed: "modalClosed" }, ngImport: i0, template: "@if (buttonTemplate(); as template) {\n <button\n type=\"button\"\n class=\"button\"\n (click)=\"onModalOpen()\"\n >\n <ng-container [ngTemplateOutlet]=\"template\" />\n </button>\n} @else {\n <button\n class=\"description\"\n cuiButton\n type=\"button\"\n appearance=\"outlined-gray\"\n icon=\"cuiIconRichText\"\n size=\"sm\"\n (click)=\"onModalOpen()\"\n [disabled]=\"isButtonDisabled()\"\n >\n @if (editorId()) {\n <span class=\"description__text _created\">{{ 'Description' }}</span>\n <cui-svg\n class=\"description__icon\"\n icon=\"cuiIconEdit\"\n color=\"var(--cui-base-500)\"\n />\n } @else {\n <cui-svg\n class=\"description__icon\"\n icon=\"cuiIconPlus\"\n color=\"var(--cui-light-blue-600)\"\n />\n <span class=\"description__text\">{{ 'Add description' }}</span>\n }\n </button>\n}\n@if (isOpen()) {\n <div class=\"wrapper\">\n @if (editorId(); as id) {\n <header class=\"header\">\n <div class=\"info\">\n <button\n cuiButton\n type=\"button\"\n icon=\"cuiIconChevronLeft\"\n size=\"xxs\"\n appearance=\"secondary\"\n shape=\"rounded\"\n (click)=\"close()\"\n ></button>\n <h1 class=\"title\">{{ title() }}</h1>\n </div>\n <div class=\"actions\">\n <!-- <cui-loader /> -->\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n (click)=\"close()\"\n >\n {{ 'Done' }}\n </button>\n </div>\n </header>\n\n <section class=\"section\">\n <cui-editor\n #editorComponent\n class=\"editor\"\n [editorApiId]=\"id\"\n [config]=\"config()\"\n />\n </section>\n }\n </div>\n}\n", styles: [":host ::ng-deep .delete{width:max-content}:host ::ng-deep .delete .c-content{display:flex;align-items:center;gap:4px;color:var(--cui-danger)}:host ::ng-deep .description .c-content{display:flex;align-items:center;gap:4px}.button{padding:0}.description{width:max-content}.description__text{color:var(--cui-light-blue-600)}.description__text._created{color:var(--cui-base-900)}.description__icon{padding:4px}.wrapper{position:fixed;z-index:10;inset:0;background-color:var(--cui-base-0)}.header{display:flex;justify-content:space-between;padding:8px 16px;border-bottom:.5px solid var(--cui-base-200);background:var(--cui-base-0)}.info,.actions{display:flex;gap:12px;align-items:center}.section{padding-right:24px;padding-left:24px;padding-top:24px;height:calc(100% - 50px);overflow:hidden}.title{font-weight:500;font-size:14px;line-height:20px;margin:0}.editor{padding-right:32px;padding-left:32px;padding-top:32px;display:block;margin:0 auto;max-width:750px;height:100%}\n"], dependencies: [{ kind: "component", type: CuiEditorComponent, selector: "cui-editor", inputs: ["editorApiId", "config", "requestSize"], outputs: ["editorEmpty"] }, { kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i1.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "size"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i2.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }] }); }
37
37
  }
38
38
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiEditorModalComponent, decorators: [{
39
39
  type: Component,
@@ -42,6 +42,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
42
42
  CuiButtonModule,
43
43
  NgTemplateOutlet,
44
44
  CuiSvgModule
45
- ], standalone: true, template: "@if (buttonTemplate(); as template) {\n <button\n type=\"button\"\n class=\"button\"\n (click)=\"onModalOpen()\"\n >\n <ng-container [ngTemplateOutlet]=\"template\" />\n </button>\n} @else {\n <button\n class=\"description\"\n cuiButton\n type=\"button\"\n appearance=\"outlined-gray\"\n icon=\"cuiIconRichText\"\n size=\"sm\"\n (click)=\"onModalOpen()\"\n [disabled]=\"isButtonDisabled()\"\n >\n @if (editorId()) {\n <span class=\"description__text _created\">{{ 'Description' }}</span>\n <cui-svg\n class=\"description__icon\"\n icon=\"cuiIconEdit\"\n color=\"var(--cui-base-500)\"\n />\n } @else {\n <cui-svg\n class=\"description__icon\"\n icon=\"cuiIconPlus\"\n color=\"var(--cui-light-blue-600)\"\n />\n <span class=\"description__text\">{{ 'Add description' }}</span>\n }\n </button>\n}\n@if (isOpen()) {\n <div class=\"wrapper\">\n @if (editorId(); as id) {\n <header class=\"header\">\n <div class=\"info\">\n <button\n cuiButton\n type=\"button\"\n icon=\"cuiIconChevronLeft\"\n size=\"xxs\"\n appearance=\"secondary\"\n shape=\"rounded\"\n (click)=\"close()\"\n ></button>\n <h1 class=\"title\">{{ title() }}</h1>\n </div>\n <div class=\"actions\">\n <!-- <cui-loader /> -->\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n (click)=\"close()\"\n >\n {{ 'Done' }}\n </button>\n </div>\n </header>\n\n <section class=\"section\">\n <cui-editor\n #editorComponent\n class=\"editor\"\n [editorID]=\"id\"\n [config]=\"config()\"\n />\n </section>\n }\n </div>\n}\n", styles: [":host ::ng-deep .delete{width:max-content}:host ::ng-deep .delete .c-content{display:flex;align-items:center;gap:4px;color:var(--cui-danger)}:host ::ng-deep .description .c-content{display:flex;align-items:center;gap:4px}.button{padding:0}.description{width:max-content}.description__text{color:var(--cui-light-blue-600)}.description__text._created{color:var(--cui-base-900)}.description__icon{padding:4px}.wrapper{position:fixed;z-index:10;inset:0;background-color:var(--cui-base-0)}.header{display:flex;justify-content:space-between;padding:8px 16px;border-bottom:.5px solid var(--cui-base-200);background:var(--cui-base-0)}.info,.actions{display:flex;gap:12px;align-items:center}.section{padding-right:24px;padding-left:24px;padding-top:24px;height:calc(100% - 50px);overflow:hidden}.title{font-weight:500;font-size:14px;line-height:20px;margin:0}.editor{padding-right:32px;padding-left:32px;padding-top:32px;display:block;margin:0 auto;max-width:750px;height:100%}\n"] }]
45
+ ], standalone: true, template: "@if (buttonTemplate(); as template) {\n <button\n type=\"button\"\n class=\"button\"\n (click)=\"onModalOpen()\"\n >\n <ng-container [ngTemplateOutlet]=\"template\" />\n </button>\n} @else {\n <button\n class=\"description\"\n cuiButton\n type=\"button\"\n appearance=\"outlined-gray\"\n icon=\"cuiIconRichText\"\n size=\"sm\"\n (click)=\"onModalOpen()\"\n [disabled]=\"isButtonDisabled()\"\n >\n @if (editorId()) {\n <span class=\"description__text _created\">{{ 'Description' }}</span>\n <cui-svg\n class=\"description__icon\"\n icon=\"cuiIconEdit\"\n color=\"var(--cui-base-500)\"\n />\n } @else {\n <cui-svg\n class=\"description__icon\"\n icon=\"cuiIconPlus\"\n color=\"var(--cui-light-blue-600)\"\n />\n <span class=\"description__text\">{{ 'Add description' }}</span>\n }\n </button>\n}\n@if (isOpen()) {\n <div class=\"wrapper\">\n @if (editorId(); as id) {\n <header class=\"header\">\n <div class=\"info\">\n <button\n cuiButton\n type=\"button\"\n icon=\"cuiIconChevronLeft\"\n size=\"xxs\"\n appearance=\"secondary\"\n shape=\"rounded\"\n (click)=\"close()\"\n ></button>\n <h1 class=\"title\">{{ title() }}</h1>\n </div>\n <div class=\"actions\">\n <!-- <cui-loader /> -->\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n (click)=\"close()\"\n >\n {{ 'Done' }}\n </button>\n </div>\n </header>\n\n <section class=\"section\">\n <cui-editor\n #editorComponent\n class=\"editor\"\n [editorApiId]=\"id\"\n [config]=\"config()\"\n />\n </section>\n }\n </div>\n}\n", styles: [":host ::ng-deep .delete{width:max-content}:host ::ng-deep .delete .c-content{display:flex;align-items:center;gap:4px;color:var(--cui-danger)}:host ::ng-deep .description .c-content{display:flex;align-items:center;gap:4px}.button{padding:0}.description{width:max-content}.description__text{color:var(--cui-light-blue-600)}.description__text._created{color:var(--cui-base-900)}.description__icon{padding:4px}.wrapper{position:fixed;z-index:10;inset:0;background-color:var(--cui-base-0)}.header{display:flex;justify-content:space-between;padding:8px 16px;border-bottom:.5px solid var(--cui-base-200);background:var(--cui-base-0)}.info,.actions{display:flex;gap:12px;align-items:center}.section{padding-right:24px;padding-left:24px;padding-top:24px;height:calc(100% - 50px);overflow:hidden}.title{font-weight:500;font-size:14px;line-height:20px;margin:0}.editor{padding-right:32px;padding-left:32px;padding-top:32px;display:block;margin:0 auto;max-width:750px;height:100%}\n"] }]
46
46
  }] });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLW1vZGFsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvZWRpdG9yL3dpZGdldHMvZWRpdG9yLW1vZGFsL2VkaXRvci1tb2RhbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2VkaXRvci93aWRnZXRzL2VkaXRvci1tb2RhbC9lZGl0b3ItbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFbkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUdqRSxPQUFPLEVBQUUsZUFBZSxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7O0FBZTVELE1BQU0sT0FBTyx1QkFBdUI7SUFacEM7UUFhdUIsV0FBTSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN2QixxQkFBZ0IsR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7UUFFN0MsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUNqQyxtQkFBYyxHQUFHLEtBQUssRUFBNEIsQ0FBQztRQUNuRCxXQUFNLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBbUIsQ0FBQztRQUMzQyxhQUFRLEdBQUcsS0FBSyxFQUF1QixDQUFDO1FBRXhDLGtCQUFhLEdBQUcsTUFBTSxFQUFFLENBQUM7UUFDekIsZ0JBQVcsR0FBRyxNQUFNLEVBQUUsQ0FBQztLQXNCMUM7SUFwQmEsV0FBVztRQUNqQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRWhDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUM7WUFDbEIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBRVosT0FBTztRQUNYLENBQUM7UUFFRCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzlCLENBQUM7SUFDTSxJQUFJO1FBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVNLEtBQUs7UUFDUixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUIsQ0FBQzsrR0EvQlEsdUJBQXVCO21HQUF2Qix1QkFBdUIsc3FCQ3JCcEMsNjFFQTRFQSxvZ0NEaEVRLGtCQUFrQiwrSEFDbEIsZUFBZSwyTkFDZixnQkFBZ0IsbUpBQ2hCLFlBQVk7OzRGQU1QLHVCQUF1QjtrQkFabkMsU0FBUzsrQkFDSSxrQkFBa0IsV0FDbkI7d0JBQ0wsa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLGdCQUFnQjt3QkFDaEIsWUFBWTtxQkFDZixjQUNXLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ1RlbXBsYXRlT3V0bGV0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB0eXBlIHsgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudCwgaW5wdXQsIG91dHB1dCwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7IEN1aU51bGxhYmxlIH0gZnJvbSAnQGN1YnktdWkvY2RrJztcblxuaW1wb3J0IHsgQ3VpQnV0dG9uTW9kdWxlLCBDdWlTdmdNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi9jb21wb25lbnRzJztcbmltcG9ydCB7IEN1aUVkaXRvckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2VkaXRvci5jb21wb25lbnQnO1xuaW1wb3J0IHR5cGUgeyBDdWlFZGl0b3JDb25maWcgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdjdWktZWRpdG9yLW1vZGFsJyxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIEN1aUVkaXRvckNvbXBvbmVudCxcbiAgICAgICAgQ3VpQnV0dG9uTW9kdWxlLFxuICAgICAgICBOZ1RlbXBsYXRlT3V0bGV0LFxuICAgICAgICBDdWlTdmdNb2R1bGVcbiAgICBdLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2VkaXRvci1tb2RhbC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2VkaXRvci1tb2RhbC5jb21wb25lbnQuc2Nzcydcbn0pXG5leHBvcnQgY2xhc3MgQ3VpRWRpdG9yTW9kYWxDb21wb25lbnQge1xuICAgIHByb3RlY3RlZCByZWFkb25seSBpc09wZW4gPSBzaWduYWwoZmFsc2UpO1xuICAgIHByb3RlY3RlZCByZWFkb25seSBpc0J1dHRvbkRpc2FibGVkID0gc2lnbmFsPGJvb2xlYW4+KGZhbHNlKTtcblxuICAgIHB1YmxpYyByZWFkb25seSB0aXRsZSA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgYnV0dG9uVGVtcGxhdGUgPSBpbnB1dDxUZW1wbGF0ZVJlZjxIVE1MRWxlbWVudD4+KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IGNvbmZpZyA9IGlucHV0LnJlcXVpcmVkPEN1aUVkaXRvckNvbmZpZz4oKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgZWRpdG9ySWQgPSBpbnB1dDxDdWlOdWxsYWJsZTxzdHJpbmc+PigpO1xuXG4gICAgcHVibGljIHJlYWRvbmx5IGVkaXRvckNyZWF0ZWQgPSBvdXRwdXQoKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgbW9kYWxDbG9zZWQgPSBvdXRwdXQoKTtcblxuICAgIHByb3RlY3RlZCBvbk1vZGFsT3BlbigpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pc0J1dHRvbkRpc2FibGVkLnNldCh0cnVlKTtcblxuICAgICAgICBpZiAodGhpcy5lZGl0b3JJZCgpKSB7XG4gICAgICAgICAgICB0aGlzLm9wZW4oKTtcblxuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5lZGl0b3JDcmVhdGVkLmVtaXQoKTtcbiAgICB9XG4gICAgcHVibGljIG9wZW4oKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNPcGVuLnNldCh0cnVlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xvc2UoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNCdXR0b25EaXNhYmxlZC5zZXQoZmFsc2UpO1xuICAgICAgICB0aGlzLmlzT3Blbi5zZXQoZmFsc2UpO1xuICAgICAgICB0aGlzLm1vZGFsQ2xvc2VkLmVtaXQoKTtcbiAgICB9XG59XG4iLCJAaWYgKGJ1dHRvblRlbXBsYXRlKCk7IGFzIHRlbXBsYXRlKSB7XG4gICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgY2xhc3M9XCJidXR0b25cIlxuICAgICAgICAoY2xpY2spPVwib25Nb2RhbE9wZW4oKVwiXG4gICAgPlxuICAgICAgICA8bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cInRlbXBsYXRlXCIgLz5cbiAgICA8L2J1dHRvbj5cbn0gQGVsc2Uge1xuICAgIDxidXR0b25cbiAgICAgICAgY2xhc3M9XCJkZXNjcmlwdGlvblwiXG4gICAgICAgIGN1aUJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgYXBwZWFyYW5jZT1cIm91dGxpbmVkLWdyYXlcIlxuICAgICAgICBpY29uPVwiY3VpSWNvblJpY2hUZXh0XCJcbiAgICAgICAgc2l6ZT1cInNtXCJcbiAgICAgICAgKGNsaWNrKT1cIm9uTW9kYWxPcGVuKClcIlxuICAgICAgICBbZGlzYWJsZWRdPVwiaXNCdXR0b25EaXNhYmxlZCgpXCJcbiAgICA+XG4gICAgICAgIEBpZiAoZWRpdG9ySWQoKSkge1xuICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJkZXNjcmlwdGlvbl9fdGV4dCBfY3JlYXRlZFwiPnt7ICdEZXNjcmlwdGlvbicgfX08L3NwYW4+XG4gICAgICAgICAgICA8Y3VpLXN2Z1xuICAgICAgICAgICAgICAgIGNsYXNzPVwiZGVzY3JpcHRpb25fX2ljb25cIlxuICAgICAgICAgICAgICAgIGljb249XCJjdWlJY29uRWRpdFwiXG4gICAgICAgICAgICAgICAgY29sb3I9XCJ2YXIoLS1jdWktYmFzZS01MDApXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgIH0gQGVsc2Uge1xuICAgICAgICAgICAgPGN1aS1zdmdcbiAgICAgICAgICAgICAgICBjbGFzcz1cImRlc2NyaXB0aW9uX19pY29uXCJcbiAgICAgICAgICAgICAgICBpY29uPVwiY3VpSWNvblBsdXNcIlxuICAgICAgICAgICAgICAgIGNvbG9yPVwidmFyKC0tY3VpLWxpZ2h0LWJsdWUtNjAwKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJkZXNjcmlwdGlvbl9fdGV4dFwiPnt7ICdBZGQgZGVzY3JpcHRpb24nIH19PC9zcGFuPlxuICAgICAgICB9XG4gICAgPC9idXR0b24+XG59XG5AaWYgKGlzT3BlbigpKSB7XG4gICAgPGRpdiBjbGFzcz1cIndyYXBwZXJcIj5cbiAgICAgICAgQGlmIChlZGl0b3JJZCgpOyBhcyBpZCkge1xuICAgICAgICAgICAgPGhlYWRlciBjbGFzcz1cImhlYWRlclwiPlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJpbmZvXCI+XG4gICAgICAgICAgICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgICAgICAgICAgICAgIGN1aUJ1dHRvblxuICAgICAgICAgICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgICAgICAgICBpY29uPVwiY3VpSWNvbkNoZXZyb25MZWZ0XCJcbiAgICAgICAgICAgICAgICAgICAgICAgIHNpemU9XCJ4eHNcIlxuICAgICAgICAgICAgICAgICAgICAgICAgYXBwZWFyYW5jZT1cInNlY29uZGFyeVwiXG4gICAgICAgICAgICAgICAgICAgICAgICBzaGFwZT1cInJvdW5kZWRcIlxuICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cImNsb3NlKClcIlxuICAgICAgICAgICAgICAgICAgICA+PC9idXR0b24+XG4gICAgICAgICAgICAgICAgICAgIDxoMSBjbGFzcz1cInRpdGxlXCI+e3sgdGl0bGUoKSB9fTwvaDE+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImFjdGlvbnNcIj5cbiAgICAgICAgICAgICAgICAgICAgPCEtLSA8Y3VpLWxvYWRlciAvPiAtLT5cbiAgICAgICAgICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgICAgICAgICBjdWlCdXR0b25cbiAgICAgICAgICAgICAgICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwiY2xvc2UoKVwiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgIHt7ICdEb25lJyB9fVxuICAgICAgICAgICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDwvaGVhZGVyPlxuXG4gICAgICAgICAgICA8c2VjdGlvbiBjbGFzcz1cInNlY3Rpb25cIj5cbiAgICAgICAgICAgICAgICA8Y3VpLWVkaXRvclxuICAgICAgICAgICAgICAgICAgICAjZWRpdG9yQ29tcG9uZW50XG4gICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiZWRpdG9yXCJcbiAgICAgICAgICAgICAgICAgICAgW2VkaXRvcklEXT1cImlkXCJcbiAgICAgICAgICAgICAgICAgICAgW2NvbmZpZ109XCJjb25maWcoKVwiXG4gICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvc2VjdGlvbj5cbiAgICAgICAgfVxuICAgIDwvZGl2PlxufVxuIl19
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLW1vZGFsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvZWRpdG9yL3dpZGdldHMvZWRpdG9yLW1vZGFsL2VkaXRvci1tb2RhbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2VkaXRvci93aWRnZXRzL2VkaXRvci1tb2RhbC9lZGl0b3ItbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFbkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUdqRSxPQUFPLEVBQUUsZUFBZSxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7O0FBZTVELE1BQU0sT0FBTyx1QkFBdUI7SUFacEM7UUFhdUIsV0FBTSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN2QixxQkFBZ0IsR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7UUFFN0MsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUNqQyxtQkFBYyxHQUFHLEtBQUssRUFBNEIsQ0FBQztRQUNuRCxXQUFNLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBbUIsQ0FBQztRQUMzQyxhQUFRLEdBQUcsS0FBSyxFQUF1QixDQUFDO1FBRXhDLGtCQUFhLEdBQUcsTUFBTSxFQUFFLENBQUM7UUFDekIsZ0JBQVcsR0FBRyxNQUFNLEVBQUUsQ0FBQztLQXNCMUM7SUFwQmEsV0FBVztRQUNqQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRWhDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUM7WUFDbEIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBRVosT0FBTztRQUNYLENBQUM7UUFFRCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzlCLENBQUM7SUFDTSxJQUFJO1FBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVNLEtBQUs7UUFDUixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUIsQ0FBQzsrR0EvQlEsdUJBQXVCO21HQUF2Qix1QkFBdUIsc3FCQ3JCcEMsZzJFQTRFQSxvZ0NEaEVRLGtCQUFrQixrSUFDbEIsZUFBZSwyTkFDZixnQkFBZ0IsbUpBQ2hCLFlBQVk7OzRGQU1QLHVCQUF1QjtrQkFabkMsU0FBUzsrQkFDSSxrQkFBa0IsV0FDbkI7d0JBQ0wsa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLGdCQUFnQjt3QkFDaEIsWUFBWTtxQkFDZixjQUNXLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ1RlbXBsYXRlT3V0bGV0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB0eXBlIHsgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudCwgaW5wdXQsIG91dHB1dCwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7IEN1aU51bGxhYmxlIH0gZnJvbSAnQGN1YnktdWkvY2RrJztcblxuaW1wb3J0IHsgQ3VpQnV0dG9uTW9kdWxlLCBDdWlTdmdNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi9jb21wb25lbnRzJztcbmltcG9ydCB7IEN1aUVkaXRvckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2VkaXRvci5jb21wb25lbnQnO1xuaW1wb3J0IHR5cGUgeyBDdWlFZGl0b3JDb25maWcgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdjdWktZWRpdG9yLW1vZGFsJyxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIEN1aUVkaXRvckNvbXBvbmVudCxcbiAgICAgICAgQ3VpQnV0dG9uTW9kdWxlLFxuICAgICAgICBOZ1RlbXBsYXRlT3V0bGV0LFxuICAgICAgICBDdWlTdmdNb2R1bGVcbiAgICBdLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2VkaXRvci1tb2RhbC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2VkaXRvci1tb2RhbC5jb21wb25lbnQuc2Nzcydcbn0pXG5leHBvcnQgY2xhc3MgQ3VpRWRpdG9yTW9kYWxDb21wb25lbnQge1xuICAgIHByb3RlY3RlZCByZWFkb25seSBpc09wZW4gPSBzaWduYWwoZmFsc2UpO1xuICAgIHByb3RlY3RlZCByZWFkb25seSBpc0J1dHRvbkRpc2FibGVkID0gc2lnbmFsPGJvb2xlYW4+KGZhbHNlKTtcblxuICAgIHB1YmxpYyByZWFkb25seSB0aXRsZSA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgYnV0dG9uVGVtcGxhdGUgPSBpbnB1dDxUZW1wbGF0ZVJlZjxIVE1MRWxlbWVudD4+KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IGNvbmZpZyA9IGlucHV0LnJlcXVpcmVkPEN1aUVkaXRvckNvbmZpZz4oKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgZWRpdG9ySWQgPSBpbnB1dDxDdWlOdWxsYWJsZTxzdHJpbmc+PigpO1xuXG4gICAgcHVibGljIHJlYWRvbmx5IGVkaXRvckNyZWF0ZWQgPSBvdXRwdXQoKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgbW9kYWxDbG9zZWQgPSBvdXRwdXQoKTtcblxuICAgIHByb3RlY3RlZCBvbk1vZGFsT3BlbigpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pc0J1dHRvbkRpc2FibGVkLnNldCh0cnVlKTtcblxuICAgICAgICBpZiAodGhpcy5lZGl0b3JJZCgpKSB7XG4gICAgICAgICAgICB0aGlzLm9wZW4oKTtcblxuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5lZGl0b3JDcmVhdGVkLmVtaXQoKTtcbiAgICB9XG4gICAgcHVibGljIG9wZW4oKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNPcGVuLnNldCh0cnVlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xvc2UoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNCdXR0b25EaXNhYmxlZC5zZXQoZmFsc2UpO1xuICAgICAgICB0aGlzLmlzT3Blbi5zZXQoZmFsc2UpO1xuICAgICAgICB0aGlzLm1vZGFsQ2xvc2VkLmVtaXQoKTtcbiAgICB9XG59XG4iLCJAaWYgKGJ1dHRvblRlbXBsYXRlKCk7IGFzIHRlbXBsYXRlKSB7XG4gICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgY2xhc3M9XCJidXR0b25cIlxuICAgICAgICAoY2xpY2spPVwib25Nb2RhbE9wZW4oKVwiXG4gICAgPlxuICAgICAgICA8bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cInRlbXBsYXRlXCIgLz5cbiAgICA8L2J1dHRvbj5cbn0gQGVsc2Uge1xuICAgIDxidXR0b25cbiAgICAgICAgY2xhc3M9XCJkZXNjcmlwdGlvblwiXG4gICAgICAgIGN1aUJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgYXBwZWFyYW5jZT1cIm91dGxpbmVkLWdyYXlcIlxuICAgICAgICBpY29uPVwiY3VpSWNvblJpY2hUZXh0XCJcbiAgICAgICAgc2l6ZT1cInNtXCJcbiAgICAgICAgKGNsaWNrKT1cIm9uTW9kYWxPcGVuKClcIlxuICAgICAgICBbZGlzYWJsZWRdPVwiaXNCdXR0b25EaXNhYmxlZCgpXCJcbiAgICA+XG4gICAgICAgIEBpZiAoZWRpdG9ySWQoKSkge1xuICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJkZXNjcmlwdGlvbl9fdGV4dCBfY3JlYXRlZFwiPnt7ICdEZXNjcmlwdGlvbicgfX08L3NwYW4+XG4gICAgICAgICAgICA8Y3VpLXN2Z1xuICAgICAgICAgICAgICAgIGNsYXNzPVwiZGVzY3JpcHRpb25fX2ljb25cIlxuICAgICAgICAgICAgICAgIGljb249XCJjdWlJY29uRWRpdFwiXG4gICAgICAgICAgICAgICAgY29sb3I9XCJ2YXIoLS1jdWktYmFzZS01MDApXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgIH0gQGVsc2Uge1xuICAgICAgICAgICAgPGN1aS1zdmdcbiAgICAgICAgICAgICAgICBjbGFzcz1cImRlc2NyaXB0aW9uX19pY29uXCJcbiAgICAgICAgICAgICAgICBpY29uPVwiY3VpSWNvblBsdXNcIlxuICAgICAgICAgICAgICAgIGNvbG9yPVwidmFyKC0tY3VpLWxpZ2h0LWJsdWUtNjAwKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJkZXNjcmlwdGlvbl9fdGV4dFwiPnt7ICdBZGQgZGVzY3JpcHRpb24nIH19PC9zcGFuPlxuICAgICAgICB9XG4gICAgPC9idXR0b24+XG59XG5AaWYgKGlzT3BlbigpKSB7XG4gICAgPGRpdiBjbGFzcz1cIndyYXBwZXJcIj5cbiAgICAgICAgQGlmIChlZGl0b3JJZCgpOyBhcyBpZCkge1xuICAgICAgICAgICAgPGhlYWRlciBjbGFzcz1cImhlYWRlclwiPlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJpbmZvXCI+XG4gICAgICAgICAgICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgICAgICAgICAgICAgIGN1aUJ1dHRvblxuICAgICAgICAgICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgICAgICAgICBpY29uPVwiY3VpSWNvbkNoZXZyb25MZWZ0XCJcbiAgICAgICAgICAgICAgICAgICAgICAgIHNpemU9XCJ4eHNcIlxuICAgICAgICAgICAgICAgICAgICAgICAgYXBwZWFyYW5jZT1cInNlY29uZGFyeVwiXG4gICAgICAgICAgICAgICAgICAgICAgICBzaGFwZT1cInJvdW5kZWRcIlxuICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cImNsb3NlKClcIlxuICAgICAgICAgICAgICAgICAgICA+PC9idXR0b24+XG4gICAgICAgICAgICAgICAgICAgIDxoMSBjbGFzcz1cInRpdGxlXCI+e3sgdGl0bGUoKSB9fTwvaDE+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImFjdGlvbnNcIj5cbiAgICAgICAgICAgICAgICAgICAgPCEtLSA8Y3VpLWxvYWRlciAvPiAtLT5cbiAgICAgICAgICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgICAgICAgICBjdWlCdXR0b25cbiAgICAgICAgICAgICAgICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwiY2xvc2UoKVwiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgIHt7ICdEb25lJyB9fVxuICAgICAgICAgICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDwvaGVhZGVyPlxuXG4gICAgICAgICAgICA8c2VjdGlvbiBjbGFzcz1cInNlY3Rpb25cIj5cbiAgICAgICAgICAgICAgICA8Y3VpLWVkaXRvclxuICAgICAgICAgICAgICAgICAgICAjZWRpdG9yQ29tcG9uZW50XG4gICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiZWRpdG9yXCJcbiAgICAgICAgICAgICAgICAgICAgW2VkaXRvckFwaUlkXT1cImlkXCJcbiAgICAgICAgICAgICAgICAgICAgW2NvbmZpZ109XCJjb25maWcoKVwiXG4gICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvc2VjdGlvbj5cbiAgICAgICAgfVxuICAgIDwvZGl2PlxufVxuIl19