@cuby-ui/core 0.0.485 → 0.0.488

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.
Files changed (44) hide show
  1. package/README.md +794 -13
  2. package/editor/editor.component.d.ts +1 -0
  3. package/editor/tools/combined-text-block.tool.d.ts +0 -1
  4. package/esm2022/components/card-wrapper/card-wrapper.component.mjs +2 -2
  5. package/esm2022/components/content-header/content-header.component.mjs +3 -3
  6. package/esm2022/components/dropdown/dropdown-wrapper.component.mjs +3 -3
  7. package/esm2022/components/sidebar/sidebar-header/sidebar-header.component.mjs +3 -3
  8. package/esm2022/components/tabs/components/abstract-tabs/abstract-tabs.component.mjs +3 -3
  9. package/esm2022/editor/components/editor-attaches-tool/editor-attaches-tool.component.mjs +3 -3
  10. package/esm2022/editor/editor.component.mjs +9 -1
  11. package/esm2022/editor/tools/combined-text-block.tool.mjs +9 -26
  12. package/esm2022/editor/widgets/editor-block/editor-block.component.mjs +3 -3
  13. package/esm2022/editor/widgets/editor-modal/editor-modal.component.mjs +3 -3
  14. package/esm2022/widgets/ui/assignee-role-item/assignee-role-item.component.mjs +3 -3
  15. package/esm2022/widgets/ui/assignee-roles-tabs/assignee-roles-tabs.component.mjs +3 -3
  16. package/esm2022/widgets/ui/button-change-theme/button-change-theme.component.mjs +3 -3
  17. package/esm2022/widgets/ui/categories/components/category-form/category-form.component.mjs +3 -3
  18. package/esm2022/widgets/ui/categories/components/category-item/category-item.component.mjs +3 -3
  19. package/esm2022/widgets/ui/checklist-block/checklist-block.component.mjs +3 -3
  20. package/esm2022/widgets/ui/checklist-block/components/checklist-block-list-item-evaluation-criteria/checklist-block-list-item-evaluation-criteria.component.mjs +3 -3
  21. package/esm2022/widgets/ui/circle-loader/circle-loader.component.mjs +3 -3
  22. package/esm2022/widgets/ui/consumable-form/components/consumable-form-item/consumable-form-item.component.mjs +3 -3
  23. package/esm2022/widgets/ui/consumable-form/components/consumable-form-item-readonly/consumable-form-item-readonly.component.mjs +3 -3
  24. package/esm2022/widgets/ui/consumable-form/consumable-form.component.mjs +3 -3
  25. package/esm2022/widgets/ui/delete-modal/delete-modal.component.mjs +3 -3
  26. package/esm2022/widgets/ui/framer-preview/framer-preview.component.mjs +3 -3
  27. package/esm2022/widgets/ui/inserted/inserted.component.mjs +3 -3
  28. package/esm2022/widgets/ui/modal-header-inserted-buttons/modal-header-inserted-buttons.component.mjs +3 -3
  29. package/esm2022/widgets/ui/modal-header-tabs/modal-header-tabs.component.mjs +3 -3
  30. package/esm2022/widgets/ui/resources-block/components/resources-block-content/resources-block-content.component.mjs +3 -3
  31. package/esm2022/widgets/ui/resources-block/components/resources-options/resources-options.component.mjs +3 -3
  32. package/esm2022/widgets/ui/resources-block/resources-block.component.mjs +3 -3
  33. package/esm2022/widgets/ui/toolbox-form/components/tool-form-readonly/tool-form-readonly.component.mjs +3 -3
  34. package/esm2022/widgets/ui/toolbox-form/tool-form.component.mjs +3 -3
  35. package/esm2022/widgets/ui/user-action-context-menu/activity-item/activity-item.component.mjs +3 -3
  36. package/esm2022/widgets/ui/user-action-context-menu/company-item/company-item.component.mjs +3 -3
  37. package/esm2022/widgets/ui/user-action-context-menu/user-action-context-menu.component.mjs +3 -3
  38. package/esm2022/widgets/ui/utility-modal/components/readonly-utility-modal/readonly-utility-modal.component.mjs +3 -3
  39. package/esm2022/widgets/ui/utility-modal/components/utility-modal-create/utility-modal-create.component.mjs +3 -3
  40. package/esm2022/widgets/ui/utility-thumbnail/utility-thumbnail.component.mjs +3 -3
  41. package/fesm2022/cuby-ui-core.mjs +85 -94
  42. package/fesm2022/cuby-ui-core.mjs.map +1 -1
  43. package/package.json +4 -4
  44. package/styles/mixins/flex.scss +5 -15
@@ -1,5 +1,5 @@
1
1
  import { COMBINED_TEXT_BLOCK, COMBINED_TEXT_BLOCK_ADDED, COMBINED_TEXT_BLOCK_NAME, COMBINED_TEXT_BLOCK_PART, COMBINED_TEXT_BLOCK_REMOVED, COMBINED_TEXT_BLOCK_UPDATED, DEFAULT_PLACEHOLDER, DEFAULT_READONLY_PLACEHOLDER, SPLIT_MAX_LENGTH } from '../constants';
2
- import { recalculateIndexes, splitHTML, generateId } from '../utils';
2
+ import { generateId, splitHTML } from '../utils';
3
3
  export class CuiCombinedTextBlockTool {
4
4
  constructor(options) {
5
5
  this.TAG = 'span';
@@ -107,7 +107,7 @@ export class CuiCombinedTextBlockTool {
107
107
  save(blockContent) {
108
108
  const textBlocks = [];
109
109
  blockContent.querySelectorAll(this.TAG).forEach((span) => {
110
- textBlocks.push(this.getBlockPartObject(span.dataset['id'], span.innerHTML));
110
+ textBlocks.push(this.getBlockPartObject(span.dataset['localId'], span.innerHTML));
111
111
  });
112
112
  return textBlocks;
113
113
  }
@@ -159,25 +159,7 @@ export class CuiCombinedTextBlockTool {
159
159
  this.removeBlocks(removedElementsIds);
160
160
  this.changes.clear();
161
161
  }
162
- getNextIndex() {
163
- recalculateIndexes(this.api.blocks);
164
- const index = this.api.blocks.getCurrentBlockIndex();
165
- const block = this.api.blocks.getBlockByIndex(index);
166
- const dataIndex = Number(block?.holder.dataset['index']);
167
- const selection = window.getSelection();
168
- const range = selection?.rangeCount ? selection.getRangeAt(0) : null;
169
- const caretPosition = range?.startOffset ?? 1;
170
- let nextBlockIndex = dataIndex;
171
- if (caretPosition !== 0) {
172
- const blockContainer = block?.holder.querySelector('.' + COMBINED_TEXT_BLOCK);
173
- const childrenCount = blockContainer?.children?.length ? blockContainer?.children?.length - 1 : 0;
174
- nextBlockIndex = dataIndex + childrenCount + 1;
175
- }
176
- if (!nextBlockIndex) {
177
- nextBlockIndex ||= 0;
178
- }
179
- return nextBlockIndex;
180
- }
162
+ // RIP 13.01.2026 - private getNextIndex(): number
181
163
  getBlockPartObject(blockId, text) {
182
164
  return {
183
165
  id: blockId,
@@ -245,7 +227,7 @@ export class CuiCombinedTextBlockTool {
245
227
  return;
246
228
  }
247
229
  const addedBlocks = splicedParts.map((block) => {
248
- const blockId = block.dataset['id'];
230
+ const blockId = block.dataset['localId'];
249
231
  return {
250
232
  id: blockId,
251
233
  type: COMBINED_TEXT_BLOCK_PART,
@@ -257,7 +239,7 @@ export class CuiCombinedTextBlockTool {
257
239
  };
258
240
  });
259
241
  const previousElement = updatedElements.values().next().value;
260
- const id = previousElement?.dataset['id'];
242
+ const id = previousElement?.dataset['localId'];
261
243
  const index = Number(previousElement?.dataset['index']) + 1;
262
244
  const blockIndex = this.data.textBlocks.findIndex((block) => block.id === id);
263
245
  this.data.textBlocks.splice(blockIndex, 0, ...addedBlocks);
@@ -274,7 +256,7 @@ export class CuiCombinedTextBlockTool {
274
256
  }
275
257
  const updatedBlocks = [...updatedElements.values()].map((block) => {
276
258
  return {
277
- id: block.dataset['id'],
259
+ id: block.dataset['localId'],
278
260
  type: COMBINED_TEXT_BLOCK_PART,
279
261
  data: {
280
262
  text: block.innerHTML,
@@ -293,7 +275,7 @@ export class CuiCombinedTextBlockTool {
293
275
  if (!(node instanceof HTMLElement)) {
294
276
  return;
295
277
  }
296
- const blockId = node.dataset['id'];
278
+ const blockId = node.dataset['localId'];
297
279
  if (!blockId) {
298
280
  return;
299
281
  }
@@ -334,6 +316,7 @@ export class CuiCombinedTextBlockTool {
334
316
  textElement.classList.add(COMBINED_TEXT_BLOCK_PART);
335
317
  textElement.innerHTML = text;
336
318
  textElement.dataset['id'] = id;
319
+ textElement.dataset['localId'] = id;
337
320
  return textElement;
338
321
  }
339
322
  convertDefaultDataToCustom(data) {
@@ -377,4 +360,4 @@ export class CuiCombinedTextBlockTool {
377
360
  return config.placeholder ?? DEFAULT_PLACEHOLDER;
378
361
  }
379
362
  }
380
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combined-text-block.tool.js","sourceRoot":"","sources":["../../../../../projects/core/editor/tools/combined-text-block.tool.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CuiNullable } from '@cuby-ui/cdk';\nimport type { API, BlockTool, BlockToolConstructorOptions, ToolConfig } from '@editorjs/editorjs';\n\nimport {\n    COMBINED_TEXT_BLOCK,\n    COMBINED_TEXT_BLOCK_ADDED,\n    COMBINED_TEXT_BLOCK_NAME,\n    COMBINED_TEXT_BLOCK_PART,\n    COMBINED_TEXT_BLOCK_REMOVED,\n    COMBINED_TEXT_BLOCK_UPDATED,\n    DEFAULT_PLACEHOLDER,\n    DEFAULT_READONLY_PLACEHOLDER,\n    SPLIT_MAX_LENGTH\n} from '../constants';\nimport type {\n    CuiCombinedBlockToolData,\n    CuiCombinedPartBlock,\n    CuiMutationActions,\n    CuiMutationCallback\n} from '../interfaces';\nimport { recalculateIndexes, splitHTML, generateId } from '../utils';\n\nexport class CuiCombinedTextBlockTool implements BlockTool {\n    private readonly TAG = 'span';\n    private readonly DEBOUNCE_TIME = 350;\n    private readonly MAX_CHILD_COUNT_FOR_EMPTY = 1;\n    private readonly PLACEHOLDER_ATTRIBUTE_NAME = 'placeholderActive';\n\n    private mutationConfig = {\n        subtree: true,\n        childList: true,\n        characterData: true\n    };\n    private api: API;\n    private data: CuiCombinedBlockToolData;\n    private placeholder: string;\n    private wrapper?: HTMLElement;\n    private observer?: MutationObserver;\n    private lastBlockElement?: HTMLElement;\n    private readOnly?: boolean;\n    private changes = new Map();\n\n    constructor(options: unknown) {\n        const body = options as BlockToolConstructorOptions;\n        const data = body.data;\n\n        this.readOnly = body.readOnly;\n        this.placeholder = this.getPlaceholder(body.config);\n        this.api = body.api;\n        this.data = {\n            id: data.id || generateId(),\n            textBlocks: data.textBlocks || []\n        };\n\n        this.convertDefaultDataToCustom(data);\n    }\n\n    public static get isInline(): boolean {\n        return false;\n    }\n\n    public static get isReadOnlySupported(): boolean {\n        return true;\n    }\n\n    public static get enableLineBreaks(): boolean {\n        return false;\n    }\n\n    public static get toolbox(): { icon: string; title: string } {\n        return {\n            icon: '<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-width=\"2\" d=\"M8 9V7.2C8 7.08954 8.08954 7 8.2 7L12 7M16 9V7.2C16 7.08954 15.9105 7 15.8 7L12 7M12 7L12 17M12 17H10M12 17H14\"></path></svg>',\n            title: 'Text'\n        };\n    }\n\n    public static get pasteConfig(): object {\n        return {\n            tags: ['P']\n        };\n    }\n\n    public onPaste(event: CustomEvent): void {\n        if (event.type !== 'tag') {\n            return;\n        }\n\n        const text = event.detail.data.textContent;\n\n        this.data.textBlocks.splice(this.data.textBlocks.length - 1, 1, this.getBlockPartObject(generateId(), text));\n        this.update(this.data.textBlocks);\n    }\n\n    public render(): HTMLElement {\n        this.wrapper = document.createElement('div');\n        this.wrapper.classList.add(COMBINED_TEXT_BLOCK);\n        this.wrapper.dataset[this.PLACEHOLDER_ATTRIBUTE_NAME] = this.api.i18n.t(this.placeholder);\n\n        if (!this.readOnly) {\n            this.wrapper.contentEditable = 'true';\n        }\n\n        if (!this.data.textBlocks.length) {\n            this.data.textBlocks.push(this.getBlockPartObject(generateId(), ''));\n        }\n\n        this.update(this.data.textBlocks);\n        this.checkIsEditorEmpty();\n\n        if (!this.readOnly) {\n            const callback = this.getMutationCallback(this.DEBOUNCE_TIME);\n\n            this.observer = new MutationObserver(this.onMutationEvent.bind(this, callback));\n            this.observer.observe(this.wrapper, this.mutationConfig);\n        }\n\n        return this.wrapper;\n    }\n\n    public merge(blocksData: CuiCombinedPartBlock[]): void {\n        if (!this.wrapper) {\n            return;\n        }\n\n        let blocksTextContent = '';\n        this.data.textBlocks = [];\n\n        blocksData.forEach((block) => {\n            blocksTextContent += block.data.text;\n        });\n\n        for (let i = 0; i < this.wrapper.childNodes.length; i++) {\n            const node = this.wrapper.childNodes.item(i);\n\n            if (!(node instanceof HTMLSpanElement)) {\n                return;\n            }\n\n            i--;\n            blocksTextContent = node.innerHTML + blocksTextContent;\n            node.remove();\n        }\n\n        const parts = blocksTextContent.length < SPLIT_MAX_LENGTH ? [blocksTextContent] : splitHTML(blocksTextContent);\n\n        parts.forEach((part: string) => {\n            const blockObject = this.getBlockPartObject(generateId(), part);\n\n            this.data.textBlocks.push(blockObject);\n        });\n\n        this.update(this.data.textBlocks);\n    }\n\n    public save(blockContent: HTMLElement): CuiCombinedPartBlock[] {\n        const textBlocks: CuiCombinedPartBlock[] = [];\n\n        blockContent.querySelectorAll(this.TAG).forEach((span: HTMLElement) => {\n            textBlocks.push(this.getBlockPartObject(span.dataset['id']!, span.innerHTML));\n        });\n\n        return textBlocks;\n    }\n\n    public removed(): void {\n        this.observer?.disconnect();\n\n        const blockIds = new Set<string>();\n\n        this.data.textBlocks.forEach((block: CuiCombinedPartBlock) => {\n            blockIds.add(block.id || '');\n        });\n\n        this.removeBlocks(blockIds);\n    }\n\n    private onMutationEvent(callback: (mutationList: MutationRecord[]) => void, mutationList: MutationRecord[]): void {\n        if (mutationList.length === 0) {\n            return;\n        }\n\n        mutationList.forEach((mutation) => {\n            if (mutation.removedNodes.length) {\n                this.changes.set(generateId(), mutation);\n\n                return;\n            }\n\n            this.changes.set(mutation.target, mutation);\n        });\n\n        callback(mutationList);\n        this.checkIsEditorEmpty();\n    }\n\n    private getMutationCallback = (wait: number): CuiMutationCallback => {\n        let timeoutId: CuiNullable<ReturnType<typeof setTimeout>> = null;\n\n        return () => {\n            if (timeoutId) {\n                clearTimeout(timeoutId);\n            }\n\n            timeoutId = setTimeout(() => this.handleMutations(), wait);\n        };\n    };\n\n    private handleMutations(): void {\n        const mutationsList = [...this.changes.values()];\n        const { updatedElements, removedElementsIds } = this.getMutationActions(mutationsList);\n        const splitedParts: HTMLElement[] = [];\n\n        updatedElements.forEach((element: HTMLElement) => {\n            const elementContent: string = element.innerHTML;\n\n            if (elementContent.length < SPLIT_MAX_LENGTH) {\n                return;\n            }\n\n            const parts = splitHTML(elementContent);\n\n            parts.forEach((part: string, index) => {\n                if (index === 0) {\n                    return;\n                }\n\n                const blockId = generateId();\n                const textElement = this.createBlock(blockId, part);\n\n                splitedParts.push(textElement);\n            });\n\n            element.innerHTML = parts[0];\n            element.after(...splitedParts);\n        });\n\n        this.addBlocks(splitedParts, updatedElements);\n        this.updateBlocks(updatedElements);\n        this.removeBlocks(removedElementsIds);\n        this.changes.clear();\n    }\n\n    private getNextIndex(): number {\n        recalculateIndexes(this.api.blocks);\n        const index = this.api.blocks.getCurrentBlockIndex();\n        const block = this.api.blocks.getBlockByIndex(index);\n        const dataIndex = Number(block?.holder.dataset['index']);\n\n        const selection = window.getSelection();\n        const range = selection?.rangeCount ? selection.getRangeAt(0) : null;\n        const caretPosition = range?.startOffset ?? 1;\n\n        let nextBlockIndex = dataIndex;\n\n        if (caretPosition !== 0) {\n            const blockContainer = block?.holder.querySelector('.' + COMBINED_TEXT_BLOCK) as HTMLElement;\n            const childrenCount = blockContainer?.children?.length ? blockContainer?.children?.length - 1 : 0;\n\n            nextBlockIndex = dataIndex + childrenCount + 1;\n        }\n\n        if (!nextBlockIndex) {\n            nextBlockIndex ||= 0;\n        }\n\n        return nextBlockIndex;\n    }\n\n    private getBlockPartObject(blockId: string, text: string): CuiCombinedPartBlock {\n        return {\n            id: blockId,\n            type: COMBINED_TEXT_BLOCK_PART,\n            data: {\n                text,\n                parentId: this.data.id,\n                parentType: COMBINED_TEXT_BLOCK_NAME\n            }\n        };\n    }\n\n    private getMutationActions(mutationList: MutationRecord[]): CuiMutationActions {\n        const updatedElements = new Set<HTMLElement>();\n        const removedElementsIds = new Set<string>();\n        const changedOutsideElements: Node[] = [];\n\n        this.lastBlockElement = undefined;\n\n        mutationList.forEach((mutation: MutationRecord): void => {\n            this.handleUpdatedBlocks(mutation, updatedElements, changedOutsideElements);\n            this.handleRemovedBlocks(mutation, removedElementsIds);\n        });\n\n        if (this.lastBlockElement) {\n            const lastBlockElement = this.lastBlockElement as HTMLElement;\n\n            lastBlockElement.append(...changedOutsideElements);\n            this.setCaretToBlocksEnd(lastBlockElement);\n        }\n\n        return {\n            updatedElements,\n            removedElementsIds\n        };\n    }\n\n    private setCaretToBlocksEnd(block: HTMLElement): void {\n        const selection = window.getSelection();\n        const range = document.createRange();\n\n        range.setStart(block, block.childNodes.length);\n        selection?.removeAllRanges();\n        selection?.addRange(range);\n    }\n\n    private handleUpdatedBlocks(\n        mutation: MutationRecord,\n        updatedElements: Set<HTMLElement>,\n        outsideChanges: Node[]\n    ): void {\n        let element = mutation.target as HTMLElement;\n\n        if (mutation.target.nodeType === Node.TEXT_NODE) {\n            element = mutation.target.parentElement as HTMLElement;\n        }\n\n        const span = element?.closest('.' + COMBINED_TEXT_BLOCK_PART) as HTMLElement;\n\n        if (span) {\n            updatedElements.add(span);\n\n            return;\n        }\n\n        this.handleChangesOutsideBlock(element, outsideChanges);\n    }\n\n    private handleChangesOutsideBlock(element: HTMLElement, outsideChanges: Node[]): void {\n        if (!element || this.lastBlockElement) {\n            return;\n        }\n\n        element.childNodes.forEach((block) => {\n            const blockElement = block as HTMLElement;\n\n            if (blockElement.classList?.contains(COMBINED_TEXT_BLOCK_PART)) {\n                this.lastBlockElement = blockElement;\n\n                return;\n            }\n\n            outsideChanges.push(block);\n        });\n    }\n\n    private addBlocks(splicedParts: HTMLElement[], updatedElements: Set<HTMLElement>): void {\n        if (!splicedParts.length) {\n            return;\n        }\n\n        const addedBlocks: CuiCombinedPartBlock[] = splicedParts.map((block) => {\n            const blockId = block.dataset['id'];\n\n            return {\n                id: blockId,\n                type: COMBINED_TEXT_BLOCK_PART,\n                data: {\n                    text: block.innerHTML,\n                    parentId: this.data.id,\n                    parentType: COMBINED_TEXT_BLOCK_NAME\n                }\n            };\n        });\n\n        const previousElement = updatedElements.values().next().value;\n        const id = previousElement?.dataset['id'];\n        const index = Number(previousElement?.dataset['index']) + 1;\n        const blockIndex = this.data.textBlocks.findIndex((block) => block.id === id);\n\n        this.data.textBlocks.splice(blockIndex, 0, ...addedBlocks);\n        this.api.events.emit(COMBINED_TEXT_BLOCK_ADDED, {\n            index,\n            blockIndex,\n            blocks: addedBlocks,\n            data: this.data.textBlocks\n        });\n    }\n\n    private updateBlocks(updatedElements: Set<HTMLElement>): void {\n        if (!updatedElements.size) {\n            return;\n        }\n\n        const updatedBlocks = [...updatedElements.values()].map((block) => {\n            return {\n                id: block.dataset['id'],\n                type: COMBINED_TEXT_BLOCK_PART,\n                data: {\n                    text: block.innerHTML,\n                    parentId: this.data.id,\n                    parentType: COMBINED_TEXT_BLOCK_NAME\n                }\n            };\n        });\n\n        this.api.events.emit(COMBINED_TEXT_BLOCK_UPDATED, updatedBlocks);\n    }\n\n    private handleRemovedBlocks(mutation: MutationRecord, removedElementsIds: Set<string>): void {\n        if (mutation.removedNodes.length === 0) {\n            return;\n        }\n\n        mutation.removedNodes.forEach((node: Node): void => {\n            if (!(node instanceof HTMLElement)) {\n                return;\n            }\n\n            const blockId = (node as HTMLElement).dataset['id'];\n\n            if (!blockId) {\n                return;\n            }\n\n            removedElementsIds.add(blockId);\n        });\n    }\n\n    private removeBlocks(ids: Set<string>): void {\n        if (!ids.size) {\n            return;\n        }\n\n        const removedElementIds = [...ids.values()];\n\n        this.data.textBlocks = this.data.textBlocks.filter((block) => !ids.has(block.id || ''));\n        this.api.events.emit(COMBINED_TEXT_BLOCK_REMOVED, removedElementIds);\n    }\n\n    private update(blocks: CuiCombinedPartBlock[]): void {\n        if (!blocks.length) {\n            return;\n        }\n\n        blocks.forEach((block: CuiCombinedPartBlock) => {\n            const textElement = this.createBlock(block.id || generateId(), block.data.text);\n\n            if (!this.wrapper) {\n                return;\n            }\n\n            if (this.wrapper.querySelector('.' + COMBINED_TEXT_BLOCK_PART)) {\n                this.wrapper.append(textElement);\n\n                return;\n            }\n\n            this.wrapper.replaceChildren(textElement);\n        });\n\n        setTimeout(() => {\n            this.api.events.emit(COMBINED_TEXT_BLOCK_ADDED, {\n                blocks\n            });\n        });\n    }\n\n    private createBlock(id: string, text: string): HTMLElement {\n        const textElement = document.createElement(this.TAG);\n        textElement.classList.add(COMBINED_TEXT_BLOCK_PART);\n        textElement.innerHTML = text;\n        textElement.dataset['id'] = id;\n\n        return textElement;\n    }\n\n    private convertDefaultDataToCustom(data: { text: string }): void {\n        if (Array.isArray(data)) {\n            this.data.textBlocks = data.map((block) => {\n                block.id = generateId();\n                block.data.parentId = this.data.id;\n\n                return block;\n            });\n        }\n\n        if (!data.text) {\n            return;\n        }\n\n        const fragment = document.createRange().createContextualFragment(data.text);\n        let elementContent = '';\n\n        fragment.childNodes.forEach((node) => {\n            if (node.nodeType === Node.TEXT_NODE) {\n                elementContent += node.textContent;\n\n                return;\n            }\n\n            elementContent += (node as HTMLElement).innerHTML;\n        });\n\n        const parts = elementContent.length < SPLIT_MAX_LENGTH ? [elementContent] : splitHTML(elementContent);\n\n        parts.forEach((part: string) => {\n            const blockObject = this.getBlockPartObject(generateId(), part);\n\n            this.data.textBlocks.push(blockObject);\n        });\n    }\n\n    private checkIsEditorEmpty(): void {\n        if (!this.wrapper || this.wrapper.children.length > this.MAX_CHILD_COUNT_FOR_EMPTY) {\n            return;\n        }\n\n        const item = this.wrapper.children.item(0) as HTMLElement;\n        const isItemEmpty = !item.textContent?.length;\n\n        this.wrapper.dataset['empty'] = `${isItemEmpty}`;\n    }\n\n    private getPlaceholder(config: ToolConfig): string {\n        if (this.readOnly) {\n            return config.readonlyPlaceholder ?? DEFAULT_READONLY_PLACEHOLDER;\n        }\n\n        return config.placeholder ?? DEFAULT_PLACEHOLDER;\n    }\n}\n"]}
363
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combined-text-block.tool.js","sourceRoot":"","sources":["../../../../../projects/core/editor/tools/combined-text-block.tool.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CuiNullable } from '@cuby-ui/cdk';\nimport type { API, BlockTool, BlockToolConstructorOptions, ToolConfig } from '@editorjs/editorjs';\n\nimport {\n    COMBINED_TEXT_BLOCK,\n    COMBINED_TEXT_BLOCK_ADDED,\n    COMBINED_TEXT_BLOCK_NAME,\n    COMBINED_TEXT_BLOCK_PART,\n    COMBINED_TEXT_BLOCK_REMOVED,\n    COMBINED_TEXT_BLOCK_UPDATED,\n    DEFAULT_PLACEHOLDER,\n    DEFAULT_READONLY_PLACEHOLDER,\n    SPLIT_MAX_LENGTH\n} from '../constants';\nimport type {\n    CuiCombinedBlockToolData,\n    CuiCombinedPartBlock,\n    CuiMutationActions,\n    CuiMutationCallback\n} from '../interfaces';\nimport { generateId, splitHTML } from '../utils';\n\nexport class CuiCombinedTextBlockTool implements BlockTool {\n    private readonly TAG = 'span';\n    private readonly DEBOUNCE_TIME = 350;\n    private readonly MAX_CHILD_COUNT_FOR_EMPTY = 1;\n    private readonly PLACEHOLDER_ATTRIBUTE_NAME = 'placeholderActive';\n\n    private mutationConfig = {\n        subtree: true,\n        childList: true,\n        characterData: true\n    };\n    private api: API;\n    private data: CuiCombinedBlockToolData;\n    private placeholder: string;\n    private wrapper?: HTMLElement;\n    private observer?: MutationObserver;\n    private lastBlockElement?: HTMLElement;\n    private readOnly?: boolean;\n    private changes = new Map();\n\n    constructor(options: unknown) {\n        const body = options as BlockToolConstructorOptions;\n        const data = body.data;\n\n        this.readOnly = body.readOnly;\n        this.placeholder = this.getPlaceholder(body.config);\n        this.api = body.api;\n        this.data = {\n            id: data.id || generateId(),\n            textBlocks: data.textBlocks || []\n        };\n\n        this.convertDefaultDataToCustom(data);\n    }\n\n    public static get isInline(): boolean {\n        return false;\n    }\n\n    public static get isReadOnlySupported(): boolean {\n        return true;\n    }\n\n    public static get enableLineBreaks(): boolean {\n        return false;\n    }\n\n    public static get toolbox(): { icon: string; title: string } {\n        return {\n            icon: '<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-width=\"2\" d=\"M8 9V7.2C8 7.08954 8.08954 7 8.2 7L12 7M16 9V7.2C16 7.08954 15.9105 7 15.8 7L12 7M12 7L12 17M12 17H10M12 17H14\"></path></svg>',\n            title: 'Text'\n        };\n    }\n\n    public static get pasteConfig(): object {\n        return {\n            tags: ['P']\n        };\n    }\n\n    public onPaste(event: CustomEvent): void {\n        if (event.type !== 'tag') {\n            return;\n        }\n\n        const text = event.detail.data.textContent;\n\n        this.data.textBlocks.splice(this.data.textBlocks.length - 1, 1, this.getBlockPartObject(generateId(), text));\n        this.update(this.data.textBlocks);\n    }\n\n    public render(): HTMLElement {\n        this.wrapper = document.createElement('div');\n        this.wrapper.classList.add(COMBINED_TEXT_BLOCK);\n        this.wrapper.dataset[this.PLACEHOLDER_ATTRIBUTE_NAME] = this.api.i18n.t(this.placeholder);\n\n        if (!this.readOnly) {\n            this.wrapper.contentEditable = 'true';\n        }\n\n        if (!this.data.textBlocks.length) {\n            this.data.textBlocks.push(this.getBlockPartObject(generateId(), ''));\n        }\n\n        this.update(this.data.textBlocks);\n        this.checkIsEditorEmpty();\n\n        if (!this.readOnly) {\n            const callback = this.getMutationCallback(this.DEBOUNCE_TIME);\n\n            this.observer = new MutationObserver(this.onMutationEvent.bind(this, callback));\n            this.observer.observe(this.wrapper, this.mutationConfig);\n        }\n\n        return this.wrapper;\n    }\n\n    public merge(blocksData: CuiCombinedPartBlock[]): void {\n        if (!this.wrapper) {\n            return;\n        }\n\n        let blocksTextContent = '';\n        this.data.textBlocks = [];\n\n        blocksData.forEach((block) => {\n            blocksTextContent += block.data.text;\n        });\n\n        for (let i = 0; i < this.wrapper.childNodes.length; i++) {\n            const node = this.wrapper.childNodes.item(i);\n\n            if (!(node instanceof HTMLSpanElement)) {\n                return;\n            }\n\n            i--;\n            blocksTextContent = node.innerHTML + blocksTextContent;\n            node.remove();\n        }\n\n        const parts = blocksTextContent.length < SPLIT_MAX_LENGTH ? [blocksTextContent] : splitHTML(blocksTextContent);\n\n        parts.forEach((part: string) => {\n            const blockObject = this.getBlockPartObject(generateId(), part);\n\n            this.data.textBlocks.push(blockObject);\n        });\n\n        this.update(this.data.textBlocks);\n    }\n\n    public save(blockContent: HTMLElement): CuiCombinedPartBlock[] {\n        const textBlocks: CuiCombinedPartBlock[] = [];\n\n        blockContent.querySelectorAll(this.TAG).forEach((span: HTMLElement) => {\n            textBlocks.push(this.getBlockPartObject(span.dataset['localId']!, span.innerHTML));\n        });\n\n        return textBlocks;\n    }\n\n    public removed(): void {\n        this.observer?.disconnect();\n\n        const blockIds = new Set<string>();\n\n        this.data.textBlocks.forEach((block: CuiCombinedPartBlock) => {\n            blockIds.add(block.id || '');\n        });\n\n        this.removeBlocks(blockIds);\n    }\n\n    private onMutationEvent(callback: (mutationList: MutationRecord[]) => void, mutationList: MutationRecord[]): void {\n        if (mutationList.length === 0) {\n            return;\n        }\n\n        mutationList.forEach((mutation) => {\n            if (mutation.removedNodes.length) {\n                this.changes.set(generateId(), mutation);\n\n                return;\n            }\n\n            this.changes.set(mutation.target, mutation);\n        });\n\n        callback(mutationList);\n        this.checkIsEditorEmpty();\n    }\n\n    private getMutationCallback = (wait: number): CuiMutationCallback => {\n        let timeoutId: CuiNullable<ReturnType<typeof setTimeout>> = null;\n\n        return () => {\n            if (timeoutId) {\n                clearTimeout(timeoutId);\n            }\n\n            timeoutId = setTimeout(() => this.handleMutations(), wait);\n        };\n    };\n\n    private handleMutations(): void {\n        const mutationsList = [...this.changes.values()];\n        const { updatedElements, removedElementsIds } = this.getMutationActions(mutationsList);\n        const splitedParts: HTMLElement[] = [];\n\n        updatedElements.forEach((element: HTMLElement) => {\n            const elementContent: string = element.innerHTML;\n\n            if (elementContent.length < SPLIT_MAX_LENGTH) {\n                return;\n            }\n\n            const parts = splitHTML(elementContent);\n\n            parts.forEach((part: string, index) => {\n                if (index === 0) {\n                    return;\n                }\n\n                const blockId = generateId();\n                const textElement = this.createBlock(blockId, part);\n\n                splitedParts.push(textElement);\n            });\n\n            element.innerHTML = parts[0];\n            element.after(...splitedParts);\n        });\n\n        this.addBlocks(splitedParts, updatedElements);\n        this.updateBlocks(updatedElements);\n        this.removeBlocks(removedElementsIds);\n        this.changes.clear();\n    }\n\n    // RIP 13.01.2026 - private getNextIndex(): number\n\n    private getBlockPartObject(blockId: string, text: string): CuiCombinedPartBlock {\n        return {\n            id: blockId,\n            type: COMBINED_TEXT_BLOCK_PART,\n            data: {\n                text,\n                parentId: this.data.id,\n                parentType: COMBINED_TEXT_BLOCK_NAME\n            }\n        };\n    }\n\n    private getMutationActions(mutationList: MutationRecord[]): CuiMutationActions {\n        const updatedElements = new Set<HTMLElement>();\n        const removedElementsIds = new Set<string>();\n        const changedOutsideElements: Node[] = [];\n\n        this.lastBlockElement = undefined;\n\n        mutationList.forEach((mutation: MutationRecord): void => {\n            this.handleUpdatedBlocks(mutation, updatedElements, changedOutsideElements);\n            this.handleRemovedBlocks(mutation, removedElementsIds);\n        });\n\n        if (this.lastBlockElement) {\n            const lastBlockElement = this.lastBlockElement as HTMLElement;\n\n            lastBlockElement.append(...changedOutsideElements);\n            this.setCaretToBlocksEnd(lastBlockElement);\n        }\n\n        return {\n            updatedElements,\n            removedElementsIds\n        };\n    }\n\n    private setCaretToBlocksEnd(block: HTMLElement): void {\n        const selection = window.getSelection();\n        const range = document.createRange();\n\n        range.setStart(block, block.childNodes.length);\n        selection?.removeAllRanges();\n        selection?.addRange(range);\n    }\n\n    private handleUpdatedBlocks(\n        mutation: MutationRecord,\n        updatedElements: Set<HTMLElement>,\n        outsideChanges: Node[]\n    ): void {\n        let element = mutation.target as HTMLElement;\n\n        if (mutation.target.nodeType === Node.TEXT_NODE) {\n            element = mutation.target.parentElement as HTMLElement;\n        }\n\n        const span = element?.closest('.' + COMBINED_TEXT_BLOCK_PART) as HTMLElement;\n\n        if (span) {\n            updatedElements.add(span);\n\n            return;\n        }\n\n        this.handleChangesOutsideBlock(element, outsideChanges);\n    }\n\n    private handleChangesOutsideBlock(element: HTMLElement, outsideChanges: Node[]): void {\n        if (!element || this.lastBlockElement) {\n            return;\n        }\n\n        element.childNodes.forEach((block) => {\n            const blockElement = block as HTMLElement;\n\n            if (blockElement.classList?.contains(COMBINED_TEXT_BLOCK_PART)) {\n                this.lastBlockElement = blockElement;\n\n                return;\n            }\n\n            outsideChanges.push(block);\n        });\n    }\n\n    private addBlocks(splicedParts: HTMLElement[], updatedElements: Set<HTMLElement>): void {\n        if (!splicedParts.length) {\n            return;\n        }\n\n        const addedBlocks: CuiCombinedPartBlock[] = splicedParts.map((block) => {\n            const blockId = block.dataset['localId'];\n\n            return {\n                id: blockId,\n                type: COMBINED_TEXT_BLOCK_PART,\n                data: {\n                    text: block.innerHTML,\n                    parentId: this.data.id,\n                    parentType: COMBINED_TEXT_BLOCK_NAME\n                }\n            };\n        });\n\n        const previousElement = updatedElements.values().next().value;\n        const id = previousElement?.dataset['localId'];\n        const index = Number(previousElement?.dataset['index']) + 1;\n        const blockIndex = this.data.textBlocks.findIndex((block) => block.id === id);\n\n        this.data.textBlocks.splice(blockIndex, 0, ...addedBlocks);\n        this.api.events.emit(COMBINED_TEXT_BLOCK_ADDED, {\n            index,\n            blockIndex,\n            blocks: addedBlocks,\n            data: this.data.textBlocks\n        });\n    }\n\n    private updateBlocks(updatedElements: Set<HTMLElement>): void {\n        if (!updatedElements.size) {\n            return;\n        }\n\n        const updatedBlocks = [...updatedElements.values()].map((block) => {\n            return {\n                id: block.dataset['localId'],\n                type: COMBINED_TEXT_BLOCK_PART,\n                data: {\n                    text: block.innerHTML,\n                    parentId: this.data.id,\n                    parentType: COMBINED_TEXT_BLOCK_NAME\n                }\n            };\n        });\n\n        this.api.events.emit(COMBINED_TEXT_BLOCK_UPDATED, updatedBlocks);\n    }\n\n    private handleRemovedBlocks(mutation: MutationRecord, removedElementsIds: Set<string>): void {\n        if (mutation.removedNodes.length === 0) {\n            return;\n        }\n\n        mutation.removedNodes.forEach((node: Node): void => {\n            if (!(node instanceof HTMLElement)) {\n                return;\n            }\n\n            const blockId = (node as HTMLElement).dataset['localId'];\n\n            if (!blockId) {\n                return;\n            }\n\n            removedElementsIds.add(blockId);\n        });\n    }\n\n    private removeBlocks(ids: Set<string>): void {\n        if (!ids.size) {\n            return;\n        }\n\n        const removedElementIds = [...ids.values()];\n\n        this.data.textBlocks = this.data.textBlocks.filter((block) => !ids.has(block.id || ''));\n        this.api.events.emit(COMBINED_TEXT_BLOCK_REMOVED, removedElementIds);\n    }\n\n    private update(blocks: CuiCombinedPartBlock[]): void {\n        if (!blocks.length) {\n            return;\n        }\n\n        blocks.forEach((block: CuiCombinedPartBlock) => {\n            const textElement = this.createBlock(block.id || generateId(), block.data.text);\n\n            if (!this.wrapper) {\n                return;\n            }\n\n            if (this.wrapper.querySelector('.' + COMBINED_TEXT_BLOCK_PART)) {\n                this.wrapper.append(textElement);\n\n                return;\n            }\n\n            this.wrapper.replaceChildren(textElement);\n        });\n\n        setTimeout(() => {\n            this.api.events.emit(COMBINED_TEXT_BLOCK_ADDED, {\n                blocks\n            });\n        });\n    }\n\n    private createBlock(id: string, text: string): HTMLElement {\n        const textElement = document.createElement(this.TAG);\n\n        textElement.classList.add(COMBINED_TEXT_BLOCK_PART);\n        textElement.innerHTML = text;\n        textElement.dataset['id'] = id;\n        textElement.dataset['localId'] = id;\n\n        return textElement;\n    }\n\n    private convertDefaultDataToCustom(data: { text: string }): void {\n        if (Array.isArray(data)) {\n            this.data.textBlocks = data.map((block) => {\n                block.id = generateId();\n                block.data.parentId = this.data.id;\n\n                return block;\n            });\n        }\n\n        if (!data.text) {\n            return;\n        }\n\n        const fragment = document.createRange().createContextualFragment(data.text);\n        let elementContent = '';\n\n        fragment.childNodes.forEach((node) => {\n            if (node.nodeType === Node.TEXT_NODE) {\n                elementContent += node.textContent;\n\n                return;\n            }\n\n            elementContent += (node as HTMLElement).innerHTML;\n        });\n\n        const parts = elementContent.length < SPLIT_MAX_LENGTH ? [elementContent] : splitHTML(elementContent);\n\n        parts.forEach((part: string) => {\n            const blockObject = this.getBlockPartObject(generateId(), part);\n\n            this.data.textBlocks.push(blockObject);\n        });\n    }\n\n    private checkIsEditorEmpty(): void {\n        if (!this.wrapper || this.wrapper.children.length > this.MAX_CHILD_COUNT_FOR_EMPTY) {\n            return;\n        }\n\n        const item = this.wrapper.children.item(0) as HTMLElement;\n        const isItemEmpty = !item.textContent?.length;\n\n        this.wrapper.dataset['empty'] = `${isItemEmpty}`;\n    }\n\n    private getPlaceholder(config: ToolConfig): string {\n        if (this.readOnly) {\n            return config.readonlyPlaceholder ?? DEFAULT_READONLY_PLACEHOLDER;\n        }\n\n        return config.placeholder ?? DEFAULT_PLACEHOLDER;\n    }\n}\n"]}
@@ -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.14", ngImport: i0, type: CuiEditorBlockComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
49
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", 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", "theme", "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 }); }
49
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", 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;flex-direction:row;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", "theme", "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.14", ngImport: i0, type: CuiEditorBlockComponent, decorators: [{
52
52
  type: Component,
@@ -58,6 +58,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", 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 [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"] }]
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;flex-direction:row;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,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,CACpB,GAAG,EAAE;YACD,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,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC9B,CAAC;IACN,CAAC;+GApDQ,uBAAuB;mGAAvB,uBAAuB,ktBAQtB,UAAU,6CC5CxB,2gDA8CA,iiBDvBQ,eAAe,oOACf,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            () => {\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            },\n            { allowSignalWrites: true }\n        );\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"]}
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,CACpB,GAAG,EAAE;YACD,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,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC9B,CAAC;IACN,CAAC;+GApDQ,uBAAuB;mGAAvB,uBAAuB,ktBAQtB,UAAU,6CC5CxB,2gDA8CA,ojBDvBQ,eAAe,oOACf,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            () => {\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            },\n            { allowSignalWrites: true }\n        );\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,10 +33,10 @@ export class CuiEditorModalComponent {
33
33
  this.modalClosed.emit();
34
34
  }
35
35
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiEditorModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
36
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", 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", "theme", "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.14", 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;flex-direction:row;gap:0;align-items:stretch;justify-content:space-between;padding:8px 16px;border-bottom:.5px solid var(--cui-base-200);background:var(--cui-base-0)}.info,.actions{display:flex;flex-direction:row;gap:12px;align-items:center;justify-content:flex-start}.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", "theme", "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.14", ngImport: i0, type: CuiEditorModalComponent, decorators: [{
39
39
  type: Component,
40
- args: [{ selector: 'cui-editor-modal', imports: [CuiEditorComponent, CuiButtonModule, NgTemplateOutlet, CuiSvgModule], 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"] }]
40
+ args: [{ selector: 'cui-editor-modal', imports: [CuiEditorComponent, CuiButtonModule, NgTemplateOutlet, CuiSvgModule], 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;flex-direction:row;gap:0;align-items:stretch;justify-content:space-between;padding:8px 16px;border-bottom:.5px solid var(--cui-base-200);background:var(--cui-base-0)}.info,.actions{display:flex;flex-direction:row;gap:12px;align-items:center;justify-content:flex-start}.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"] }]
41
41
  }] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLW1vZGFsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvZWRpdG9yL3dpZGdldHMvZWRpdG9yLW1vZGFsL2VkaXRvci1tb2RhbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2VkaXRvci93aWRnZXRzL2VkaXRvci1tb2RhbC9lZGl0b3ItbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFbkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUdqRSxPQUFPLEVBQUUsZUFBZSxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7O0FBVTVELE1BQU0sT0FBTyx1QkFBdUI7SUFQcEM7UUFRdUIsV0FBTSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN2QixxQkFBZ0IsR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7UUFFN0MsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUNqQyxtQkFBYyxHQUFHLEtBQUssRUFBNEIsQ0FBQztRQUNuRCxXQUFNLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBbUIsQ0FBQztRQUMzQyxhQUFRLEdBQUcsS0FBSyxFQUF1QixDQUFDO1FBRXhDLGtCQUFhLEdBQUcsTUFBTSxFQUFFLENBQUM7UUFDekIsZ0JBQVcsR0FBRyxNQUFNLEVBQUUsQ0FBQztLQXNCMUM7SUFwQmEsV0FBVztRQUNqQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRWhDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUM7WUFDbEIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBRVosT0FBTztRQUNYLENBQUM7UUFFRCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzlCLENBQUM7SUFDTSxJQUFJO1FBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVNLEtBQUs7UUFDUixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUIsQ0FBQzsrR0EvQlEsdUJBQXVCO21HQUF2Qix1QkFBdUIsc3FCQ2hCcEMsZzJFQTRFQSxvZ0NEakVjLGtCQUFrQixrSUFBRSxlQUFlLG9PQUFFLGdCQUFnQixtSkFBRSxZQUFZOzs0RkFLcEUsdUJBQXVCO2tCQVBuQyxTQUFTOytCQUNJLGtCQUFrQixXQUNuQixDQUFDLGtCQUFrQixFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxZQUFZLENBQUMsY0FDbEUsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHR5cGUgeyBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgb3V0cHV0LCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHsgQ3VpTnVsbGFibGUgfSBmcm9tICdAY3VieS11aS9jZGsnO1xuXG5pbXBvcnQgeyBDdWlCdXR0b25Nb2R1bGUsIEN1aVN2Z01vZHVsZSB9IGZyb20gJy4uLy4uLy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgQ3VpRWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vZWRpdG9yLmNvbXBvbmVudCc7XG5pbXBvcnQgdHlwZSB7IEN1aUVkaXRvckNvbmZpZyB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2N1aS1lZGl0b3ItbW9kYWwnLFxuICAgIGltcG9ydHM6IFtDdWlFZGl0b3JDb21wb25lbnQsIEN1aUJ1dHRvbk1vZHVsZSwgTmdUZW1wbGF0ZU91dGxldCwgQ3VpU3ZnTW9kdWxlXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9lZGl0b3ItbW9kYWwuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsOiAnLi9lZGl0b3ItbW9kYWwuY29tcG9uZW50LnNjc3MnXG59KVxuZXhwb3J0IGNsYXNzIEN1aUVkaXRvck1vZGFsQ29tcG9uZW50IHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaXNPcGVuID0gc2lnbmFsKGZhbHNlKTtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaXNCdXR0b25EaXNhYmxlZCA9IHNpZ25hbDxib29sZWFuPihmYWxzZSk7XG5cbiAgICBwdWJsaWMgcmVhZG9ubHkgdGl0bGUgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IGJ1dHRvblRlbXBsYXRlID0gaW5wdXQ8VGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+PigpO1xuICAgIHB1YmxpYyByZWFkb25seSBjb25maWcgPSBpbnB1dC5yZXF1aXJlZDxDdWlFZGl0b3JDb25maWc+KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IGVkaXRvcklkID0gaW5wdXQ8Q3VpTnVsbGFibGU8c3RyaW5nPj4oKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBlZGl0b3JDcmVhdGVkID0gb3V0cHV0KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IG1vZGFsQ2xvc2VkID0gb3V0cHV0KCk7XG5cbiAgICBwcm90ZWN0ZWQgb25Nb2RhbE9wZW4oKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNCdXR0b25EaXNhYmxlZC5zZXQodHJ1ZSk7XG5cbiAgICAgICAgaWYgKHRoaXMuZWRpdG9ySWQoKSkge1xuICAgICAgICAgICAgdGhpcy5vcGVuKCk7XG5cbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuZWRpdG9yQ3JlYXRlZC5lbWl0KCk7XG4gICAgfVxuICAgIHB1YmxpYyBvcGVuKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzT3Blbi5zZXQodHJ1ZSk7XG4gICAgfVxuXG4gICAgcHVibGljIGNsb3NlKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzQnV0dG9uRGlzYWJsZWQuc2V0KGZhbHNlKTtcbiAgICAgICAgdGhpcy5pc09wZW4uc2V0KGZhbHNlKTtcbiAgICAgICAgdGhpcy5tb2RhbENsb3NlZC5lbWl0KCk7XG4gICAgfVxufVxuIiwiQGlmIChidXR0b25UZW1wbGF0ZSgpOyBhcyB0ZW1wbGF0ZSkge1xuICAgIDxidXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIGNsYXNzPVwiYnV0dG9uXCJcbiAgICAgICAgKGNsaWNrKT1cIm9uTW9kYWxPcGVuKClcIlxuICAgID5cbiAgICAgICAgPG5nLWNvbnRhaW5lciBbbmdUZW1wbGF0ZU91dGxldF09XCJ0ZW1wbGF0ZVwiIC8+XG4gICAgPC9idXR0b24+XG59IEBlbHNlIHtcbiAgICA8YnV0dG9uXG4gICAgICAgIGNsYXNzPVwiZGVzY3JpcHRpb25cIlxuICAgICAgICBjdWlCdXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIGFwcGVhcmFuY2U9XCJvdXRsaW5lZC1ncmF5XCJcbiAgICAgICAgaWNvbj1cImN1aUljb25SaWNoVGV4dFwiXG4gICAgICAgIHNpemU9XCJzbVwiXG4gICAgICAgIChjbGljayk9XCJvbk1vZGFsT3BlbigpXCJcbiAgICAgICAgW2Rpc2FibGVkXT1cImlzQnV0dG9uRGlzYWJsZWQoKVwiXG4gICAgPlxuICAgICAgICBAaWYgKGVkaXRvcklkKCkpIHtcbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZGVzY3JpcHRpb25fX3RleHQgX2NyZWF0ZWRcIj57eyAnRGVzY3JpcHRpb24nIH19PC9zcGFuPlxuICAgICAgICAgICAgPGN1aS1zdmdcbiAgICAgICAgICAgICAgICBjbGFzcz1cImRlc2NyaXB0aW9uX19pY29uXCJcbiAgICAgICAgICAgICAgICBpY29uPVwiY3VpSWNvbkVkaXRcIlxuICAgICAgICAgICAgICAgIGNvbG9yPVwidmFyKC0tY3VpLWJhc2UtNTAwKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICB9IEBlbHNlIHtcbiAgICAgICAgICAgIDxjdWktc3ZnXG4gICAgICAgICAgICAgICAgY2xhc3M9XCJkZXNjcmlwdGlvbl9faWNvblwiXG4gICAgICAgICAgICAgICAgaWNvbj1cImN1aUljb25QbHVzXCJcbiAgICAgICAgICAgICAgICBjb2xvcj1cInZhcigtLWN1aS1saWdodC1ibHVlLTYwMClcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZGVzY3JpcHRpb25fX3RleHRcIj57eyAnQWRkIGRlc2NyaXB0aW9uJyB9fTwvc3Bhbj5cbiAgICAgICAgfVxuICAgIDwvYnV0dG9uPlxufVxuQGlmIChpc09wZW4oKSkge1xuICAgIDxkaXYgY2xhc3M9XCJ3cmFwcGVyXCI+XG4gICAgICAgIEBpZiAoZWRpdG9ySWQoKTsgYXMgaWQpIHtcbiAgICAgICAgICAgIDxoZWFkZXIgY2xhc3M9XCJoZWFkZXJcIj5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiaW5mb1wiPlxuICAgICAgICAgICAgICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgICAgICAgICAgICAgICBjdWlCdXR0b25cbiAgICAgICAgICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgICAgICAgICAgaWNvbj1cImN1aUljb25DaGV2cm9uTGVmdFwiXG4gICAgICAgICAgICAgICAgICAgICAgICBzaXplPVwieHhzXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIGFwcGVhcmFuY2U9XCJzZWNvbmRhcnlcIlxuICAgICAgICAgICAgICAgICAgICAgICAgc2hhcGU9XCJyb3VuZGVkXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJjbG9zZSgpXCJcbiAgICAgICAgICAgICAgICAgICAgPjwvYnV0dG9uPlxuICAgICAgICAgICAgICAgICAgICA8aDEgY2xhc3M9XCJ0aXRsZVwiPnt7IHRpdGxlKCkgfX08L2gxPlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJhY3Rpb25zXCI+XG4gICAgICAgICAgICAgICAgICAgIDwhLS0gPGN1aS1sb2FkZXIgLz4gLS0+XG4gICAgICAgICAgICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgICAgICAgICAgY3VpQnV0dG9uXG4gICAgICAgICAgICAgICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cImNsb3NlKClcIlxuICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAgICB7eyAnRG9uZScgfX1cbiAgICAgICAgICAgICAgICAgICAgPC9idXR0b24+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2hlYWRlcj5cblxuICAgICAgICAgICAgPHNlY3Rpb24gY2xhc3M9XCJzZWN0aW9uXCI+XG4gICAgICAgICAgICAgICAgPGN1aS1lZGl0b3JcbiAgICAgICAgICAgICAgICAgICAgI2VkaXRvckNvbXBvbmVudFxuICAgICAgICAgICAgICAgICAgICBjbGFzcz1cImVkaXRvclwiXG4gICAgICAgICAgICAgICAgICAgIFtlZGl0b3JBcGlJZF09XCJpZFwiXG4gICAgICAgICAgICAgICAgICAgIFtjb25maWddPVwiY29uZmlnKClcIlxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L3NlY3Rpb24+XG4gICAgICAgIH1cbiAgICA8L2Rpdj5cbn1cbiJdfQ==
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLW1vZGFsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvZWRpdG9yL3dpZGdldHMvZWRpdG9yLW1vZGFsL2VkaXRvci1tb2RhbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2VkaXRvci93aWRnZXRzL2VkaXRvci1tb2RhbC9lZGl0b3ItbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFbkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUdqRSxPQUFPLEVBQUUsZUFBZSxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7O0FBVTVELE1BQU0sT0FBTyx1QkFBdUI7SUFQcEM7UUFRdUIsV0FBTSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN2QixxQkFBZ0IsR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7UUFFN0MsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUNqQyxtQkFBYyxHQUFHLEtBQUssRUFBNEIsQ0FBQztRQUNuRCxXQUFNLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBbUIsQ0FBQztRQUMzQyxhQUFRLEdBQUcsS0FBSyxFQUF1QixDQUFDO1FBRXhDLGtCQUFhLEdBQUcsTUFBTSxFQUFFLENBQUM7UUFDekIsZ0JBQVcsR0FBRyxNQUFNLEVBQUUsQ0FBQztLQXNCMUM7SUFwQmEsV0FBVztRQUNqQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRWhDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUM7WUFDbEIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBRVosT0FBTztRQUNYLENBQUM7UUFFRCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzlCLENBQUM7SUFDTSxJQUFJO1FBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVNLEtBQUs7UUFDUixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUIsQ0FBQzsrR0EvQlEsdUJBQXVCO21HQUF2Qix1QkFBdUIsc3FCQ2hCcEMsZzJFQTRFQSwrbENEakVjLGtCQUFrQixrSUFBRSxlQUFlLG9PQUFFLGdCQUFnQixtSkFBRSxZQUFZOzs0RkFLcEUsdUJBQXVCO2tCQVBuQyxTQUFTOytCQUNJLGtCQUFrQixXQUNuQixDQUFDLGtCQUFrQixFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxZQUFZLENBQUMsY0FDbEUsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHR5cGUgeyBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgb3V0cHV0LCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHsgQ3VpTnVsbGFibGUgfSBmcm9tICdAY3VieS11aS9jZGsnO1xuXG5pbXBvcnQgeyBDdWlCdXR0b25Nb2R1bGUsIEN1aVN2Z01vZHVsZSB9IGZyb20gJy4uLy4uLy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgQ3VpRWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vZWRpdG9yLmNvbXBvbmVudCc7XG5pbXBvcnQgdHlwZSB7IEN1aUVkaXRvckNvbmZpZyB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2N1aS1lZGl0b3ItbW9kYWwnLFxuICAgIGltcG9ydHM6IFtDdWlFZGl0b3JDb21wb25lbnQsIEN1aUJ1dHRvbk1vZHVsZSwgTmdUZW1wbGF0ZU91dGxldCwgQ3VpU3ZnTW9kdWxlXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9lZGl0b3ItbW9kYWwuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsOiAnLi9lZGl0b3ItbW9kYWwuY29tcG9uZW50LnNjc3MnXG59KVxuZXhwb3J0IGNsYXNzIEN1aUVkaXRvck1vZGFsQ29tcG9uZW50IHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaXNPcGVuID0gc2lnbmFsKGZhbHNlKTtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaXNCdXR0b25EaXNhYmxlZCA9IHNpZ25hbDxib29sZWFuPihmYWxzZSk7XG5cbiAgICBwdWJsaWMgcmVhZG9ubHkgdGl0bGUgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IGJ1dHRvblRlbXBsYXRlID0gaW5wdXQ8VGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+PigpO1xuICAgIHB1YmxpYyByZWFkb25seSBjb25maWcgPSBpbnB1dC5yZXF1aXJlZDxDdWlFZGl0b3JDb25maWc+KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IGVkaXRvcklkID0gaW5wdXQ8Q3VpTnVsbGFibGU8c3RyaW5nPj4oKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBlZGl0b3JDcmVhdGVkID0gb3V0cHV0KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IG1vZGFsQ2xvc2VkID0gb3V0cHV0KCk7XG5cbiAgICBwcm90ZWN0ZWQgb25Nb2RhbE9wZW4oKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNCdXR0b25EaXNhYmxlZC5zZXQodHJ1ZSk7XG5cbiAgICAgICAgaWYgKHRoaXMuZWRpdG9ySWQoKSkge1xuICAgICAgICAgICAgdGhpcy5vcGVuKCk7XG5cbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuZWRpdG9yQ3JlYXRlZC5lbWl0KCk7XG4gICAgfVxuICAgIHB1YmxpYyBvcGVuKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzT3Blbi5zZXQodHJ1ZSk7XG4gICAgfVxuXG4gICAgcHVibGljIGNsb3NlKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzQnV0dG9uRGlzYWJsZWQuc2V0KGZhbHNlKTtcbiAgICAgICAgdGhpcy5pc09wZW4uc2V0KGZhbHNlKTtcbiAgICAgICAgdGhpcy5tb2RhbENsb3NlZC5lbWl0KCk7XG4gICAgfVxufVxuIiwiQGlmIChidXR0b25UZW1wbGF0ZSgpOyBhcyB0ZW1wbGF0ZSkge1xuICAgIDxidXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIGNsYXNzPVwiYnV0dG9uXCJcbiAgICAgICAgKGNsaWNrKT1cIm9uTW9kYWxPcGVuKClcIlxuICAgID5cbiAgICAgICAgPG5nLWNvbnRhaW5lciBbbmdUZW1wbGF0ZU91dGxldF09XCJ0ZW1wbGF0ZVwiIC8+XG4gICAgPC9idXR0b24+XG59IEBlbHNlIHtcbiAgICA8YnV0dG9uXG4gICAgICAgIGNsYXNzPVwiZGVzY3JpcHRpb25cIlxuICAgICAgICBjdWlCdXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIGFwcGVhcmFuY2U9XCJvdXRsaW5lZC1ncmF5XCJcbiAgICAgICAgaWNvbj1cImN1aUljb25SaWNoVGV4dFwiXG4gICAgICAgIHNpemU9XCJzbVwiXG4gICAgICAgIChjbGljayk9XCJvbk1vZGFsT3BlbigpXCJcbiAgICAgICAgW2Rpc2FibGVkXT1cImlzQnV0dG9uRGlzYWJsZWQoKVwiXG4gICAgPlxuICAgICAgICBAaWYgKGVkaXRvcklkKCkpIHtcbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZGVzY3JpcHRpb25fX3RleHQgX2NyZWF0ZWRcIj57eyAnRGVzY3JpcHRpb24nIH19PC9zcGFuPlxuICAgICAgICAgICAgPGN1aS1zdmdcbiAgICAgICAgICAgICAgICBjbGFzcz1cImRlc2NyaXB0aW9uX19pY29uXCJcbiAgICAgICAgICAgICAgICBpY29uPVwiY3VpSWNvbkVkaXRcIlxuICAgICAgICAgICAgICAgIGNvbG9yPVwidmFyKC0tY3VpLWJhc2UtNTAwKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICB9IEBlbHNlIHtcbiAgICAgICAgICAgIDxjdWktc3ZnXG4gICAgICAgICAgICAgICAgY2xhc3M9XCJkZXNjcmlwdGlvbl9faWNvblwiXG4gICAgICAgICAgICAgICAgaWNvbj1cImN1aUljb25QbHVzXCJcbiAgICAgICAgICAgICAgICBjb2xvcj1cInZhcigtLWN1aS1saWdodC1ibHVlLTYwMClcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZGVzY3JpcHRpb25fX3RleHRcIj57eyAnQWRkIGRlc2NyaXB0aW9uJyB9fTwvc3Bhbj5cbiAgICAgICAgfVxuICAgIDwvYnV0dG9uPlxufVxuQGlmIChpc09wZW4oKSkge1xuICAgIDxkaXYgY2xhc3M9XCJ3cmFwcGVyXCI+XG4gICAgICAgIEBpZiAoZWRpdG9ySWQoKTsgYXMgaWQpIHtcbiAgICAgICAgICAgIDxoZWFkZXIgY2xhc3M9XCJoZWFkZXJcIj5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiaW5mb1wiPlxuICAgICAgICAgICAgICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgICAgICAgICAgICAgICBjdWlCdXR0b25cbiAgICAgICAgICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgICAgICAgICAgaWNvbj1cImN1aUljb25DaGV2cm9uTGVmdFwiXG4gICAgICAgICAgICAgICAgICAgICAgICBzaXplPVwieHhzXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIGFwcGVhcmFuY2U9XCJzZWNvbmRhcnlcIlxuICAgICAgICAgICAgICAgICAgICAgICAgc2hhcGU9XCJyb3VuZGVkXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJjbG9zZSgpXCJcbiAgICAgICAgICAgICAgICAgICAgPjwvYnV0dG9uPlxuICAgICAgICAgICAgICAgICAgICA8aDEgY2xhc3M9XCJ0aXRsZVwiPnt7IHRpdGxlKCkgfX08L2gxPlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJhY3Rpb25zXCI+XG4gICAgICAgICAgICAgICAgICAgIDwhLS0gPGN1aS1sb2FkZXIgLz4gLS0+XG4gICAgICAgICAgICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgICAgICAgICAgY3VpQnV0dG9uXG4gICAgICAgICAgICAgICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cImNsb3NlKClcIlxuICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAgICB7eyAnRG9uZScgfX1cbiAgICAgICAgICAgICAgICAgICAgPC9idXR0b24+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2hlYWRlcj5cblxuICAgICAgICAgICAgPHNlY3Rpb24gY2xhc3M9XCJzZWN0aW9uXCI+XG4gICAgICAgICAgICAgICAgPGN1aS1lZGl0b3JcbiAgICAgICAgICAgICAgICAgICAgI2VkaXRvckNvbXBvbmVudFxuICAgICAgICAgICAgICAgICAgICBjbGFzcz1cImVkaXRvclwiXG4gICAgICAgICAgICAgICAgICAgIFtlZGl0b3JBcGlJZF09XCJpZFwiXG4gICAgICAgICAgICAgICAgICAgIFtjb25maWddPVwiY29uZmlnKClcIlxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L3NlY3Rpb24+XG4gICAgICAgIH1cbiAgICA8L2Rpdj5cbn1cbiJdfQ==
@@ -22,10 +22,10 @@ export class AssigneeRoleItemComponent {
22
22
  this.deleteClicked = output();
23
23
  }
24
24
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AssigneeRoleItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
25
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: AssigneeRoleItemComponent, isStandalone: true, selector: "cui-assignee-role-item", inputs: { role: { classPropertyName: "role", publicName: "role", isSignal: true, isRequired: true, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, empty: { classPropertyName: "empty", publicName: "empty", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { deleteClicked: "deleteClicked" }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\n <span></span>\n <span\n class=\"title\"\n [cuiTooltip]=\"role()\"\n >\n {{ role() }}\n </span>\n\n @if (!readonly()) {\n @if (empty()) {\n <cui-alert-hint\n status=\"warning\"\n [tooltipText]=\"t('NO_ENTITIES_ADDED')\"\n />\n }\n <cui-options-button [options]=\"OPTIONS\" />\n } @else {\n <span></span>\n }\n</ng-container>\n", styles: [":host{display:flex;gap:8px;align-items:center;justify-content:center;width:100%}.title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}\n"], dependencies: [{ kind: "directive", type: i1.CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }, { kind: "component", type: AlertHintComponent, selector: "cui-alert-hint", inputs: ["status", "tooltipText"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: OptionsButtonComponent, selector: "cui-options-button", inputs: ["options", "hoverBackgroundColor"] }] }); }
25
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: AssigneeRoleItemComponent, isStandalone: true, selector: "cui-assignee-role-item", inputs: { role: { classPropertyName: "role", publicName: "role", isSignal: true, isRequired: true, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, empty: { classPropertyName: "empty", publicName: "empty", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { deleteClicked: "deleteClicked" }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\n <span></span>\n <span\n class=\"title\"\n [cuiTooltip]=\"role()\"\n >\n {{ role() }}\n </span>\n\n @if (!readonly()) {\n @if (empty()) {\n <cui-alert-hint\n status=\"warning\"\n [tooltipText]=\"t('NO_ENTITIES_ADDED')\"\n />\n }\n <cui-options-button [options]=\"OPTIONS\" />\n } @else {\n <span></span>\n }\n</ng-container>\n", styles: [":host{display:flex;flex-direction:row;gap:8px;align-items:center;justify-content:center;width:100%}.title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}\n"], dependencies: [{ kind: "directive", type: i1.CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }, { kind: "component", type: AlertHintComponent, selector: "cui-alert-hint", inputs: ["status", "tooltipText"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: OptionsButtonComponent, selector: "cui-options-button", inputs: ["options", "hoverBackgroundColor"] }] }); }
26
26
  }
27
27
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AssigneeRoleItemComponent, decorators: [{
28
28
  type: Component,
29
- args: [{ selector: 'cui-assignee-role-item', standalone: true, imports: [CuiTooltip, AlertHintComponent, TranslocoDirective, OptionsButtonComponent], template: "<ng-container *transloco=\"let t\">\n <span></span>\n <span\n class=\"title\"\n [cuiTooltip]=\"role()\"\n >\n {{ role() }}\n </span>\n\n @if (!readonly()) {\n @if (empty()) {\n <cui-alert-hint\n status=\"warning\"\n [tooltipText]=\"t('NO_ENTITIES_ADDED')\"\n />\n }\n <cui-options-button [options]=\"OPTIONS\" />\n } @else {\n <span></span>\n }\n</ng-container>\n", styles: [":host{display:flex;gap:8px;align-items:center;justify-content:center;width:100%}.title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}\n"] }]
29
+ args: [{ selector: 'cui-assignee-role-item', standalone: true, imports: [CuiTooltip, AlertHintComponent, TranslocoDirective, OptionsButtonComponent], template: "<ng-container *transloco=\"let t\">\n <span></span>\n <span\n class=\"title\"\n [cuiTooltip]=\"role()\"\n >\n {{ role() }}\n </span>\n\n @if (!readonly()) {\n @if (empty()) {\n <cui-alert-hint\n status=\"warning\"\n [tooltipText]=\"t('NO_ENTITIES_ADDED')\"\n />\n }\n <cui-options-button [options]=\"OPTIONS\" />\n } @else {\n <span></span>\n }\n</ng-container>\n", styles: [":host{display:flex;flex-direction:row;gap:8px;align-items:center;justify-content:center;width:100%}.title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}\n"] }]
30
30
  }] });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy91aS9hc3NpZ25lZS1yb2xlLWl0ZW0vYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy91aS9hc3NpZ25lZS1yb2xlLWl0ZW0vYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFMUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQ3pGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDZEQUE2RCxDQUFDOzs7QUFTckcsTUFBTSxPQUFPLHlCQUF5QjtJQVB0QztRQVFxQixxQkFBZ0IsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUUxQyxZQUFPLEdBQXlCO1lBQy9DO2dCQUNJLEtBQUssRUFBRSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQztnQkFDaEQsSUFBSSxFQUFFLGNBQWM7Z0JBQ3BCLEtBQUssRUFBRSxtQkFBbUI7Z0JBQzFCLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRTthQUMzQztTQUNKLENBQUM7UUFFYyxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ2hDLGFBQVEsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsVUFBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVyQixrQkFBYSxHQUFHLE1BQU0sRUFBRSxDQUFDO0tBQzVDOytHQWpCWSx5QkFBeUI7bUdBQXpCLHlCQUF5Qix3ZkNkdEMsdWVBcUJBLCtZRFgwQixrQkFBa0IsOEZBQUUsa0JBQWtCLGdNQUFFLHNCQUFzQjs7NEZBSTNFLHlCQUF5QjtrQkFQckMsU0FBUzsrQkFDSSx3QkFBd0IsY0FDdEIsSUFBSSxXQUNQLENBQUMsVUFBVSxFQUFFLGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbG9jb0RpcmVjdGl2ZSwgVHJhbnNsb2NvU2VydmljZSB9IGZyb20gJ0Bqc3ZlcnNlL3RyYW5zbG9jbyc7XG5pbXBvcnQgeyBDdWlDb250ZXh0TWVudUl0ZW0gfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEN1aVRvb2x0aXAgfSBmcm9tICcuLi8uLi8uLi9kaXJlY3RpdmVzJztcbmltcG9ydCB7IEFsZXJ0SGludENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL2NvbXBvbmVudHMvYWxlcnQtaGludC9hbGVydC1oaW50LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBPcHRpb25zQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cy9vcHRpb25zLWJ1dHRvbi9vcHRpb25zLWJ1dHRvbi5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2N1aS1hc3NpZ25lZS1yb2xlLWl0ZW0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0N1aVRvb2x0aXAsIEFsZXJ0SGludENvbXBvbmVudCwgVHJhbnNsb2NvRGlyZWN0aXZlLCBPcHRpb25zQnV0dG9uQ29tcG9uZW50XSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC5zY3NzJ1xufSlcbmV4cG9ydCBjbGFzcyBBc3NpZ25lZVJvbGVJdGVtQ29tcG9uZW50IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHRyYW5zbG9jb1NlcnZpY2UgPSBpbmplY3QoVHJhbnNsb2NvU2VydmljZSk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgT1BUSU9OUzogQ3VpQ29udGV4dE1lbnVJdGVtW10gPSBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIGxhYmVsOiB0aGlzLnRyYW5zbG9jb1NlcnZpY2UudHJhbnNsYXRlKCdERUxFVEUnKSxcbiAgICAgICAgICAgIGljb246ICdjdWlJY29uVHJhc2gnLFxuICAgICAgICAgICAgY29sb3I6ICd2YXIoLS1jdWktZGFuZ2VyKScsXG4gICAgICAgICAgICBjb21tYW5kOiAoKSA9PiB0aGlzLmRlbGV0ZUNsaWNrZWQuZW1pdCgpXG4gICAgICAgIH1cbiAgICBdO1xuXG4gICAgcHVibGljIHJlYWRvbmx5IHJvbGUgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IHJlYWRvbmx5ID0gaW5wdXQoZmFsc2UpO1xuICAgIHB1YmxpYyByZWFkb25seSBlbXB0eSA9IGlucHV0KGZhbHNlKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBkZWxldGVDbGlja2VkID0gb3V0cHV0KCk7XG59XG4iLCI8bmctY29udGFpbmVyICp0cmFuc2xvY289XCJsZXQgdFwiPlxuICAgIDxzcGFuPjwvc3Bhbj5cbiAgICA8c3BhblxuICAgICAgICBjbGFzcz1cInRpdGxlXCJcbiAgICAgICAgW2N1aVRvb2x0aXBdPVwicm9sZSgpXCJcbiAgICA+XG4gICAgICAgIHt7IHJvbGUoKSB9fVxuICAgIDwvc3Bhbj5cblxuICAgIEBpZiAoIXJlYWRvbmx5KCkpIHtcbiAgICAgICAgQGlmIChlbXB0eSgpKSB7XG4gICAgICAgICAgICA8Y3VpLWFsZXJ0LWhpbnRcbiAgICAgICAgICAgICAgICBzdGF0dXM9XCJ3YXJuaW5nXCJcbiAgICAgICAgICAgICAgICBbdG9vbHRpcFRleHRdPVwidCgnTk9fRU5USVRJRVNfQURERUQnKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICB9XG4gICAgICAgIDxjdWktb3B0aW9ucy1idXR0b24gW29wdGlvbnNdPVwiT1BUSU9OU1wiIC8+XG4gICAgfSBAZWxzZSB7XG4gICAgICAgIDxzcGFuPjwvc3Bhbj5cbiAgICB9XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy91aS9hc3NpZ25lZS1yb2xlLWl0ZW0vYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy91aS9hc3NpZ25lZS1yb2xlLWl0ZW0vYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFMUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQ3pGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDZEQUE2RCxDQUFDOzs7QUFTckcsTUFBTSxPQUFPLHlCQUF5QjtJQVB0QztRQVFxQixxQkFBZ0IsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUUxQyxZQUFPLEdBQXlCO1lBQy9DO2dCQUNJLEtBQUssRUFBRSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQztnQkFDaEQsSUFBSSxFQUFFLGNBQWM7Z0JBQ3BCLEtBQUssRUFBRSxtQkFBbUI7Z0JBQzFCLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRTthQUMzQztTQUNKLENBQUM7UUFFYyxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ2hDLGFBQVEsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsVUFBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVyQixrQkFBYSxHQUFHLE1BQU0sRUFBRSxDQUFDO0tBQzVDOytHQWpCWSx5QkFBeUI7bUdBQXpCLHlCQUF5Qix3ZkNkdEMsdWVBcUJBLGthRFgwQixrQkFBa0IsOEZBQUUsa0JBQWtCLGdNQUFFLHNCQUFzQjs7NEZBSTNFLHlCQUF5QjtrQkFQckMsU0FBUzsrQkFDSSx3QkFBd0IsY0FDdEIsSUFBSSxXQUNQLENBQUMsVUFBVSxFQUFFLGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbG9jb0RpcmVjdGl2ZSwgVHJhbnNsb2NvU2VydmljZSB9IGZyb20gJ0Bqc3ZlcnNlL3RyYW5zbG9jbyc7XG5pbXBvcnQgeyBDdWlDb250ZXh0TWVudUl0ZW0gfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEN1aVRvb2x0aXAgfSBmcm9tICcuLi8uLi8uLi9kaXJlY3RpdmVzJztcbmltcG9ydCB7IEFsZXJ0SGludENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL2NvbXBvbmVudHMvYWxlcnQtaGludC9hbGVydC1oaW50LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBPcHRpb25zQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cy9vcHRpb25zLWJ1dHRvbi9vcHRpb25zLWJ1dHRvbi5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2N1aS1hc3NpZ25lZS1yb2xlLWl0ZW0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0N1aVRvb2x0aXAsIEFsZXJ0SGludENvbXBvbmVudCwgVHJhbnNsb2NvRGlyZWN0aXZlLCBPcHRpb25zQnV0dG9uQ29tcG9uZW50XSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vYXNzaWduZWUtcm9sZS1pdGVtLmNvbXBvbmVudC5zY3NzJ1xufSlcbmV4cG9ydCBjbGFzcyBBc3NpZ25lZVJvbGVJdGVtQ29tcG9uZW50IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHRyYW5zbG9jb1NlcnZpY2UgPSBpbmplY3QoVHJhbnNsb2NvU2VydmljZSk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgT1BUSU9OUzogQ3VpQ29udGV4dE1lbnVJdGVtW10gPSBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIGxhYmVsOiB0aGlzLnRyYW5zbG9jb1NlcnZpY2UudHJhbnNsYXRlKCdERUxFVEUnKSxcbiAgICAgICAgICAgIGljb246ICdjdWlJY29uVHJhc2gnLFxuICAgICAgICAgICAgY29sb3I6ICd2YXIoLS1jdWktZGFuZ2VyKScsXG4gICAgICAgICAgICBjb21tYW5kOiAoKSA9PiB0aGlzLmRlbGV0ZUNsaWNrZWQuZW1pdCgpXG4gICAgICAgIH1cbiAgICBdO1xuXG4gICAgcHVibGljIHJlYWRvbmx5IHJvbGUgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IHJlYWRvbmx5ID0gaW5wdXQoZmFsc2UpO1xuICAgIHB1YmxpYyByZWFkb25seSBlbXB0eSA9IGlucHV0KGZhbHNlKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBkZWxldGVDbGlja2VkID0gb3V0cHV0KCk7XG59XG4iLCI8bmctY29udGFpbmVyICp0cmFuc2xvY289XCJsZXQgdFwiPlxuICAgIDxzcGFuPjwvc3Bhbj5cbiAgICA8c3BhblxuICAgICAgICBjbGFzcz1cInRpdGxlXCJcbiAgICAgICAgW2N1aVRvb2x0aXBdPVwicm9sZSgpXCJcbiAgICA+XG4gICAgICAgIHt7IHJvbGUoKSB9fVxuICAgIDwvc3Bhbj5cblxuICAgIEBpZiAoIXJlYWRvbmx5KCkpIHtcbiAgICAgICAgQGlmIChlbXB0eSgpKSB7XG4gICAgICAgICAgICA8Y3VpLWFsZXJ0LWhpbnRcbiAgICAgICAgICAgICAgICBzdGF0dXM9XCJ3YXJuaW5nXCJcbiAgICAgICAgICAgICAgICBbdG9vbHRpcFRleHRdPVwidCgnTk9fRU5USVRJRVNfQURERUQnKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICB9XG4gICAgICAgIDxjdWktb3B0aW9ucy1idXR0b24gW29wdGlvbnNdPVwiT1BUSU9OU1wiIC8+XG4gICAgfSBAZWxzZSB7XG4gICAgICAgIDxzcGFuPjwvc3Bhbj5cbiAgICB9XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==