@cuby-ui/core 0.0.227 → 0.0.230
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/button/button.component.d.ts +1 -1
- package/components/content-wrapper/content-wrapper.component.d.ts +11 -0
- package/components/content-wrapper/index.d.ts +1 -0
- package/components/empty-state/empty-state.component.d.ts +7 -0
- package/components/empty-state/index.d.ts +1 -0
- package/components/ghost-input/ghost-input.component.d.ts +6 -0
- package/components/ghost-input/index.d.ts +1 -0
- package/components/index.d.ts +3 -0
- package/components/sidebar/sidebar-header/sidebar-header.component.d.ts +1 -1
- package/components/sidebar/sidebar-navigation-item/sidebar-navigation-item.component.d.ts +1 -1
- package/directives/tooltip/tooltip.component.d.ts +1 -1
- package/editor/components/editor-attaches-tool/editor-attaches-tool.component.d.ts +44 -0
- package/editor/components/editor-attaches-tool/editor-attaches-tool.options.d.ts +17 -0
- package/editor/components/editor-attaches-tool/index.d.ts +2 -0
- package/editor/components/editor-image-tool/editor-image-tool.component.d.ts +14 -0
- package/editor/components/editor-image-tool/editor-image-tool.options.d.ts +26 -0
- package/editor/components/editor-image-tool/index.d.ts +2 -0
- package/editor/components/editor-tool/editor-tool.component.d.ts +22 -0
- package/editor/components/editor-tool-modal/editor-tool-modal.component.d.ts +24 -0
- package/editor/components/editor-tool-modal/editor-tool-modal.options.d.ts +8 -0
- package/editor/components/editor-tool-modal/index.d.ts +2 -0
- package/editor/components/editor-tooltip/editor-tooltip.component.d.ts +16 -0
- package/editor/components/editor-tooltip/editor-tooltip.options.d.ts +9 -0
- package/editor/components/editor-tooltip/index.d.ts +2 -0
- package/editor/components/editor-video-tool/editor-video-tool.component.d.ts +12 -0
- package/editor/components/editor-video-tool/editor-video-tool.options.d.ts +26 -0
- package/editor/components/editor-video-tool/index.d.ts +2 -0
- package/editor/components/index.d.ts +7 -0
- package/editor/components/marker-modal/index.d.ts +3 -0
- package/editor/components/marker-modal/marker-modal.component.d.ts +62 -0
- package/editor/components/marker-modal/marker-modal.interfaces.d.ts +7 -0
- package/editor/components/marker-modal/marker-modal.options.d.ts +1 -0
- package/editor/components/marker-select/component/select-item/select-option.component.d.ts +7 -0
- package/editor/components/marker-select/index.d.ts +2 -0
- package/editor/components/marker-select/marker-select.component.d.ts +40 -0
- package/editor/components/marker-select/marker-select.options.d.ts +1 -0
- package/editor/config/custom-elements.d.ts +2 -0
- package/editor/config/editor.config.d.ts +3 -0
- package/editor/config/editor.provider.d.ts +2 -0
- package/editor/config/index.d.ts +2 -0
- package/editor/constants/editor.constants.d.ts +15 -0
- package/editor/constants/index.d.ts +1 -0
- package/editor/editor.component.d.ts +71 -0
- package/editor/events/editor-drag.event.d.ts +2 -0
- package/editor/events/editor-keyboard.event.d.ts +2 -0
- package/editor/events/editor-modal.event.d.ts +3 -0
- package/editor/events/editor-tooltip.event.d.ts +2 -0
- package/editor/events/set-editor-events.d.ts +1 -0
- package/editor/index.d.ts +9 -0
- package/editor/interfaces/angular-element.d.ts +2 -0
- package/editor/interfaces/blocks-request-data.d.ts +6 -0
- package/editor/interfaces/combined-block-adding-event.d.ts +7 -0
- package/editor/interfaces/combined-block-data.d.ts +5 -0
- package/editor/interfaces/combined-part-block-data.d.ts +7 -0
- package/editor/interfaces/custom-element.d.ts +5 -0
- package/editor/interfaces/event-action-data.d.ts +5 -0
- package/editor/interfaces/file-response-data.d.ts +10 -0
- package/editor/interfaces/full-block-data.d.ts +8 -0
- package/editor/interfaces/index.d.ts +14 -0
- package/editor/interfaces/main-editor-config.d.ts +15 -0
- package/editor/interfaces/mutation-actions.d.ts +5 -0
- package/editor/interfaces/parent.d.ts +4 -0
- package/editor/interfaces/tools.d.ts +4 -0
- package/editor/interfaces/tune.d.ts +6 -0
- package/editor/pipes/file-size.pipe.d.ts +9 -0
- package/editor/services/editor-service.options.d.ts +8 -0
- package/editor/services/editor.service.d.ts +23 -0
- package/editor/services/index.d.ts +6 -0
- package/editor/services/jtext-api.options.d.ts +20 -0
- package/editor/services/jtext-api.service.d.ts +23 -0
- package/editor/services/markers-service.options.d.ts +4 -0
- package/editor/services/markers.service.d.ts +11 -0
- package/editor/tools/attaches.tool.d.ts +28 -0
- package/editor/tools/bold.tool.d.ts +11 -0
- package/editor/tools/combined-text-block.tool.d.ts +49 -0
- package/editor/tools/custom-marker.tool.d.ts +16 -0
- package/editor/tools/header.tool.d.ts +8 -0
- package/editor/tools/image.tool.d.ts +37 -0
- package/editor/tools/index.d.ts +11 -0
- package/editor/tools/italic.tool.d.ts +12 -0
- package/editor/tools/link-marker.tool.d.ts +15 -0
- package/editor/tools/list.tool.d.ts +5 -0
- package/editor/tools/marker.tool.d.ts +36 -0
- package/editor/tools/role-marker.tool.d.ts +7 -0
- package/editor/tools/selection-base.tool.d.ts +24 -0
- package/editor/tools/tool-marker.tool.d.ts +7 -0
- package/editor/tools/video.tool.d.ts +32 -0
- package/editor/utils/create-link-modal.d.ts +3 -0
- package/editor/utils/create-tool-modal.d.ts +4 -0
- package/editor/utils/create-tooltip.d.ts +8 -0
- package/editor/utils/file-uploader.d.ts +26 -0
- package/editor/utils/generate-id.d.ts +1 -0
- package/editor/utils/index.d.ts +9 -0
- package/editor/utils/recalculate-indexes.d.ts +2 -0
- package/editor/utils/remove-element-tag-wrapper.d.ts +1 -0
- package/editor/utils/split-html.d.ts +1 -0
- package/editor/utils/url.validator.d.ts +2 -0
- package/editor/widgets/editor-block/editor-block.component.d.ts +22 -0
- package/editor/widgets/editor-block/index.d.ts +1 -0
- package/editor/widgets/editor-modal/editor-modal.component.d.ts +19 -0
- package/editor/widgets/editor-modal/index.d.ts +1 -0
- package/editor/widgets/editor-readonly/editor-readonly.component.d.ts +28 -0
- package/editor/widgets/editor-readonly/editor-readonly.options.d.ts +5 -0
- package/editor/widgets/editor-readonly/index.d.ts +2 -0
- package/editor/widgets/index.d.ts +3 -0
- package/esm2022/components/breadcrumbs/breadcrumbs.component.mjs +2 -2
- package/esm2022/components/content-wrapper/content-wrapper.component.mjs +29 -0
- package/esm2022/components/content-wrapper/index.mjs +2 -0
- package/esm2022/components/empty-state/empty-state.component.mjs +17 -0
- package/esm2022/components/empty-state/index.mjs +2 -0
- package/esm2022/components/ghost-input/ghost-input.component.mjs +16 -0
- package/esm2022/components/ghost-input/index.mjs +2 -0
- package/esm2022/components/index.mjs +4 -1
- package/esm2022/directives/tooltip/tooltip-describe.directive.mjs +5 -3
- package/esm2022/directives/tooltip/tooltip-position.directive.mjs +6 -3
- package/esm2022/directives/tooltip/tooltip.component.mjs +6 -3
- package/esm2022/editor/components/editor-attaches-tool/editor-attaches-tool.component.mjs +76 -0
- package/esm2022/editor/components/editor-attaches-tool/editor-attaches-tool.options.mjs +2 -0
- package/esm2022/editor/components/editor-attaches-tool/index.mjs +3 -0
- package/esm2022/editor/components/editor-image-tool/editor-image-tool.component.mjs +43 -0
- package/esm2022/editor/components/editor-image-tool/editor-image-tool.options.mjs +2 -0
- package/esm2022/editor/components/editor-image-tool/index.mjs +3 -0
- package/esm2022/editor/components/editor-tool/editor-tool.component.mjs +74 -0
- package/esm2022/editor/components/editor-tool-modal/editor-tool-modal.component.mjs +69 -0
- package/esm2022/editor/components/editor-tool-modal/editor-tool-modal.options.mjs +2 -0
- package/esm2022/editor/components/editor-tool-modal/index.mjs +3 -0
- package/esm2022/editor/components/editor-tooltip/editor-tooltip.component.mjs +45 -0
- package/esm2022/editor/components/editor-tooltip/editor-tooltip.options.mjs +2 -0
- package/esm2022/editor/components/editor-tooltip/index.mjs +3 -0
- package/esm2022/editor/components/editor-video-tool/editor-video-tool.component.mjs +41 -0
- package/esm2022/editor/components/editor-video-tool/editor-video-tool.options.mjs +2 -0
- package/esm2022/editor/components/editor-video-tool/index.mjs +3 -0
- package/esm2022/editor/components/index.mjs +8 -0
- package/esm2022/editor/components/marker-modal/index.mjs +3 -0
- package/esm2022/editor/components/marker-modal/marker-modal.component.mjs +261 -0
- package/esm2022/editor/components/marker-modal/marker-modal.interfaces.mjs +2 -0
- package/esm2022/editor/components/marker-modal/marker-modal.options.mjs +2 -0
- package/esm2022/editor/components/marker-select/component/select-item/select-option.component.mjs +15 -0
- package/esm2022/editor/components/marker-select/index.mjs +3 -0
- package/esm2022/editor/components/marker-select/marker-select.component.mjs +155 -0
- package/esm2022/editor/components/marker-select/marker-select.options.mjs +2 -0
- package/esm2022/editor/config/custom-elements.mjs +32 -0
- package/esm2022/editor/config/editor.config.mjs +30 -0
- package/esm2022/editor/config/editor.provider.mjs +19 -0
- package/esm2022/editor/config/index.mjs +3 -0
- package/esm2022/editor/constants/editor.constants.mjs +20 -0
- package/esm2022/editor/constants/index.mjs +2 -0
- package/esm2022/editor/editor.component.mjs +380 -0
- package/esm2022/editor/events/editor-drag.event.mjs +7 -0
- package/esm2022/editor/events/editor-keyboard.event.mjs +33 -0
- package/esm2022/editor/events/editor-modal.event.mjs +31 -0
- package/esm2022/editor/events/editor-tooltip.event.mjs +63 -0
- package/esm2022/editor/events/set-editor-events.mjs +11 -0
- package/esm2022/editor/i18n/en.json +14 -0
- package/esm2022/editor/index.mjs +8 -0
- package/esm2022/editor/interfaces/angular-element.mjs +2 -0
- package/esm2022/editor/interfaces/blocks-request-data.mjs +2 -0
- package/esm2022/editor/interfaces/combined-block-adding-event.mjs +2 -0
- package/esm2022/editor/interfaces/combined-block-data.mjs +2 -0
- package/esm2022/editor/interfaces/combined-part-block-data.mjs +2 -0
- package/esm2022/editor/interfaces/custom-element.mjs +2 -0
- package/esm2022/editor/interfaces/event-action-data.mjs +2 -0
- package/esm2022/editor/interfaces/file-response-data.mjs +2 -0
- package/esm2022/editor/interfaces/full-block-data.mjs +2 -0
- package/esm2022/editor/interfaces/index.mjs +14 -0
- package/esm2022/editor/interfaces/main-editor-config.mjs +2 -0
- package/esm2022/editor/interfaces/mutation-actions.mjs +2 -0
- package/esm2022/editor/interfaces/parent.mjs +2 -0
- package/esm2022/editor/interfaces/tools.mjs +2 -0
- package/esm2022/editor/interfaces/tune.mjs +2 -0
- package/esm2022/editor/pipes/file-size.pipe.mjs +25 -0
- package/esm2022/editor/services/editor-service.options.mjs +4 -0
- package/esm2022/editor/services/editor.service.mjs +138 -0
- package/esm2022/editor/services/index.mjs +7 -0
- package/esm2022/editor/services/jtext-api.options.mjs +2 -0
- package/esm2022/editor/services/jtext-api.service.mjs +50 -0
- package/esm2022/editor/services/markers-service.options.mjs +2 -0
- package/esm2022/editor/services/markers.service.mjs +79 -0
- package/esm2022/editor/tools/attaches.tool.mjs +96 -0
- package/esm2022/editor/tools/bold.tool.mjs +33 -0
- package/esm2022/editor/tools/combined-text-block.tool.mjs +380 -0
- package/esm2022/editor/tools/custom-marker.tool.mjs +88 -0
- package/esm2022/editor/tools/header.tool.mjs +16 -0
- package/esm2022/editor/tools/image.tool.mjs +157 -0
- package/esm2022/editor/tools/index.mjs +12 -0
- package/esm2022/editor/tools/italic.tool.mjs +35 -0
- package/esm2022/editor/tools/link-marker.tool.mjs +80 -0
- package/esm2022/editor/tools/list.tool.mjs +10 -0
- package/esm2022/editor/tools/marker.tool.mjs +144 -0
- package/esm2022/editor/tools/role-marker.tool.mjs +17 -0
- package/esm2022/editor/tools/selection-base.tool.mjs +92 -0
- package/esm2022/editor/tools/tool-marker.tool.mjs +14 -0
- package/esm2022/editor/tools/video.tool.mjs +132 -0
- package/esm2022/editor/utils/create-link-modal.mjs +22 -0
- package/esm2022/editor/utils/create-tool-modal.mjs +45 -0
- package/esm2022/editor/utils/create-tooltip.mjs +44 -0
- package/esm2022/editor/utils/file-uploader.mjs +57 -0
- package/esm2022/editor/utils/generate-id.mjs +4 -0
- package/esm2022/editor/utils/index.mjs +10 -0
- package/esm2022/editor/utils/recalculate-indexes.mjs +32 -0
- package/esm2022/editor/utils/remove-element-tag-wrapper.mjs +11 -0
- package/esm2022/editor/utils/split-html.mjs +128 -0
- package/esm2022/editor/utils/url.validator.mjs +12 -0
- package/esm2022/editor/widgets/editor-block/editor-block.component.mjs +63 -0
- package/esm2022/editor/widgets/editor-block/index.mjs +2 -0
- package/esm2022/editor/widgets/editor-modal/editor-modal.component.mjs +47 -0
- package/esm2022/editor/widgets/editor-modal/index.mjs +2 -0
- package/esm2022/editor/widgets/editor-readonly/editor-readonly.component.mjs +40 -0
- package/esm2022/editor/widgets/editor-readonly/editor-readonly.options.mjs +2 -0
- package/esm2022/editor/widgets/editor-readonly/index.mjs +2 -0
- package/esm2022/editor/widgets/index.mjs +4 -0
- package/esm2022/index.mjs +3 -1
- package/esm2022/interceptors/loader.interceptor.mjs +3 -3
- package/esm2022/services/loader.options.mjs +2 -2
- package/esm2022/services/loader.service.mjs +11 -11
- package/esm2022/utils/default-validators/create-default-validators.mjs +12 -0
- package/esm2022/utils/default-validators/extra-spaces.options.mjs +11 -0
- package/esm2022/utils/default-validators/extra-spaces.validators.mjs +16 -0
- package/esm2022/utils/default-validators/index.mjs +2 -0
- package/esm2022/utils/index.mjs +2 -1
- package/esm2022/widgets/categories/categories.component.mjs +75 -0
- package/esm2022/widgets/categories/components/categories-list/categories-list.component.mjs +16 -0
- package/esm2022/widgets/categories/components/categories-list/index.mjs +2 -0
- package/esm2022/widgets/categories/components/category-form/category-form.component.mjs +79 -0
- package/esm2022/widgets/categories/components/category-form/index.mjs +2 -0
- package/esm2022/widgets/categories/components/category-item/category-item.component.mjs +123 -0
- package/esm2022/widgets/categories/components/category-item/index.mjs +2 -0
- package/esm2022/widgets/categories/components/create-category-item/create-category-item.component.mjs +25 -0
- package/esm2022/widgets/categories/components/create-category-item/index.mjs +2 -0
- package/esm2022/widgets/categories/components/index.mjs +3 -0
- package/esm2022/widgets/categories/index.mjs +2 -0
- package/esm2022/widgets/categories/services/index.mjs +2 -0
- package/esm2022/widgets/categories/services/selected-category.service.mjs +38 -0
- package/esm2022/widgets/general-control-error-hint/general-control-error-hint.component.mjs +21 -0
- package/esm2022/widgets/general-control-error-hint/index.mjs +2 -0
- package/esm2022/widgets/index.mjs +3 -0
- package/esm2022/widgets/utility-info/index.mjs +2 -0
- package/esm2022/widgets/utility-info/utility-info.component.mjs +224 -0
- package/fesm2022/cuby-ui-core-en-D3DnyYmu.mjs +29 -0
- package/fesm2022/cuby-ui-core-en-D3DnyYmu.mjs.map +1 -0
- package/fesm2022/cuby-ui-core.mjs +4047 -67
- package/fesm2022/cuby-ui-core.mjs.map +1 -1
- package/index.d.ts +2 -0
- package/package.json +3 -3
- package/services/loader.options.d.ts +2 -2
- package/services/loader.service.d.ts +7 -7
- package/utils/default-validators/create-default-validators.d.ts +5 -0
- package/utils/default-validators/extra-spaces.options.d.ts +2 -0
- package/utils/default-validators/extra-spaces.validators.d.ts +3 -0
- package/utils/default-validators/index.d.ts +1 -0
- package/utils/index.d.ts +1 -0
- package/widgets/categories/categories.component.d.ts +24 -0
- package/widgets/categories/components/categories-list/categories-list.component.d.ts +7 -0
- package/widgets/categories/components/categories-list/index.d.ts +1 -0
- package/widgets/categories/components/category-form/category-form.component.d.ts +28 -0
- package/widgets/categories/components/category-form/index.d.ts +1 -0
- package/widgets/categories/components/category-item/category-item.component.d.ts +40 -0
- package/widgets/categories/components/category-item/index.d.ts +1 -0
- package/widgets/categories/components/create-category-item/create-category-item.component.d.ts +10 -0
- package/widgets/categories/components/create-category-item/index.d.ts +1 -0
- package/widgets/categories/components/index.d.ts +2 -0
- package/widgets/categories/index.d.ts +1 -0
- package/widgets/categories/services/index.d.ts +1 -0
- package/widgets/categories/services/selected-category.service.d.ts +18 -0
- package/widgets/general-control-error-hint/general-control-error-hint.component.d.ts +9 -0
- package/widgets/general-control-error-hint/index.d.ts +1 -0
- package/widgets/index.d.ts +2 -0
- package/widgets/utility-info/index.d.ts +1 -0
- package/widgets/utility-info/utility-info.component.d.ts +45 -0
|
@@ -0,0 +1,380 @@
|
|
|
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';
|
|
3
|
+
export class CuiCombinedTextBlockTool {
|
|
4
|
+
constructor(options) {
|
|
5
|
+
this.TAG = 'span';
|
|
6
|
+
this.DEBOUNCE_TIME = 350;
|
|
7
|
+
this.MAX_CHILD_COUNT_FOR_EMPTY = 1;
|
|
8
|
+
this.PLACEHOLDER_ATTRIBUTE_NAME = 'placeholderActive';
|
|
9
|
+
this.mutationConfig = {
|
|
10
|
+
subtree: true,
|
|
11
|
+
childList: true,
|
|
12
|
+
characterData: true
|
|
13
|
+
};
|
|
14
|
+
this.changes = new Map();
|
|
15
|
+
this.getMutationCallback = (wait) => {
|
|
16
|
+
let timeoutId = null;
|
|
17
|
+
return () => {
|
|
18
|
+
if (timeoutId) {
|
|
19
|
+
clearTimeout(timeoutId);
|
|
20
|
+
}
|
|
21
|
+
timeoutId = setTimeout(() => this.handleMutations(), wait);
|
|
22
|
+
};
|
|
23
|
+
};
|
|
24
|
+
const body = options;
|
|
25
|
+
const data = body.data;
|
|
26
|
+
this.readOnly = body.readOnly;
|
|
27
|
+
this.placeholder = this.getPlaceholder(body.config);
|
|
28
|
+
this.api = body.api;
|
|
29
|
+
this.data = {
|
|
30
|
+
id: data.id || generateId(),
|
|
31
|
+
textBlocks: data.textBlocks || []
|
|
32
|
+
};
|
|
33
|
+
this.convertDefaultDataToCustom(data);
|
|
34
|
+
}
|
|
35
|
+
static get isInline() {
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
static get isReadOnlySupported() {
|
|
39
|
+
return true;
|
|
40
|
+
}
|
|
41
|
+
static get enableLineBreaks() {
|
|
42
|
+
return false;
|
|
43
|
+
}
|
|
44
|
+
static get toolbox() {
|
|
45
|
+
return {
|
|
46
|
+
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>',
|
|
47
|
+
title: 'Text'
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
static get pasteConfig() {
|
|
51
|
+
return {
|
|
52
|
+
tags: ['P']
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
onPaste(event) {
|
|
56
|
+
if (event.type !== 'tag') {
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const text = event.detail.data.textContent;
|
|
60
|
+
this.data.textBlocks.splice(this.data.textBlocks.length - 1, 1, this.getBlockPartObject(generateId(), text));
|
|
61
|
+
this.update(this.data.textBlocks);
|
|
62
|
+
}
|
|
63
|
+
render() {
|
|
64
|
+
this.wrapper = document.createElement('div');
|
|
65
|
+
this.wrapper.classList.add(COMBINED_TEXT_BLOCK);
|
|
66
|
+
this.wrapper.dataset[this.PLACEHOLDER_ATTRIBUTE_NAME] = this.api.i18n.t(this.placeholder);
|
|
67
|
+
if (!this.readOnly) {
|
|
68
|
+
this.wrapper.contentEditable = 'true';
|
|
69
|
+
}
|
|
70
|
+
if (!this.data.textBlocks.length) {
|
|
71
|
+
this.data.textBlocks.push(this.getBlockPartObject(generateId(), ''));
|
|
72
|
+
}
|
|
73
|
+
this.update(this.data.textBlocks);
|
|
74
|
+
this.checkIsEditorEmpty();
|
|
75
|
+
if (!this.readOnly) {
|
|
76
|
+
const callback = this.getMutationCallback(this.DEBOUNCE_TIME);
|
|
77
|
+
this.observer = new MutationObserver(this.onMutationEvent.bind(this, callback));
|
|
78
|
+
this.observer.observe(this.wrapper, this.mutationConfig);
|
|
79
|
+
}
|
|
80
|
+
return this.wrapper;
|
|
81
|
+
}
|
|
82
|
+
merge(blocksData) {
|
|
83
|
+
if (!this.wrapper) {
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
let blocksTextContent = '';
|
|
87
|
+
this.data.textBlocks = [];
|
|
88
|
+
blocksData.forEach((block) => {
|
|
89
|
+
blocksTextContent += block.data.text;
|
|
90
|
+
});
|
|
91
|
+
for (let i = 0; i < this.wrapper.childNodes.length; i++) {
|
|
92
|
+
const node = this.wrapper.childNodes.item(i);
|
|
93
|
+
if (!(node instanceof HTMLSpanElement)) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
i--;
|
|
97
|
+
blocksTextContent = node.innerHTML + blocksTextContent;
|
|
98
|
+
node.remove();
|
|
99
|
+
}
|
|
100
|
+
const parts = blocksTextContent.length < SPLIT_MAX_LENGTH ? [blocksTextContent] : splitHTML(blocksTextContent);
|
|
101
|
+
parts.forEach((part) => {
|
|
102
|
+
const blockObject = this.getBlockPartObject(generateId(), part);
|
|
103
|
+
this.data.textBlocks.push(blockObject);
|
|
104
|
+
});
|
|
105
|
+
this.update(this.data.textBlocks);
|
|
106
|
+
}
|
|
107
|
+
save(blockContent) {
|
|
108
|
+
const textBlocks = [];
|
|
109
|
+
blockContent.querySelectorAll(this.TAG).forEach((span) => {
|
|
110
|
+
textBlocks.push(this.getBlockPartObject(span.dataset['id'], span.innerHTML));
|
|
111
|
+
});
|
|
112
|
+
return textBlocks;
|
|
113
|
+
}
|
|
114
|
+
removed() {
|
|
115
|
+
this.observer?.disconnect();
|
|
116
|
+
const blockIds = new Set();
|
|
117
|
+
this.data.textBlocks.forEach((block) => {
|
|
118
|
+
blockIds.add(block.id || '');
|
|
119
|
+
});
|
|
120
|
+
this.removeBlocks(blockIds);
|
|
121
|
+
}
|
|
122
|
+
onMutationEvent(callback, mutationList) {
|
|
123
|
+
if (mutationList.length === 0) {
|
|
124
|
+
return;
|
|
125
|
+
}
|
|
126
|
+
mutationList.forEach((mutation) => {
|
|
127
|
+
if (mutation.removedNodes.length) {
|
|
128
|
+
this.changes.set(generateId(), mutation);
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
this.changes.set(mutation.target, mutation);
|
|
132
|
+
});
|
|
133
|
+
callback(mutationList);
|
|
134
|
+
this.checkIsEditorEmpty();
|
|
135
|
+
}
|
|
136
|
+
handleMutations() {
|
|
137
|
+
const mutationsList = [...this.changes.values()];
|
|
138
|
+
const { updatedElements, removedElementsIds } = this.getMutationActions(mutationsList);
|
|
139
|
+
const splitedParts = [];
|
|
140
|
+
updatedElements.forEach((element) => {
|
|
141
|
+
const elementContent = element.innerHTML;
|
|
142
|
+
if (elementContent.length < SPLIT_MAX_LENGTH) {
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
const parts = splitHTML(elementContent);
|
|
146
|
+
parts.forEach((part, index) => {
|
|
147
|
+
if (index === 0) {
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
const blockId = generateId();
|
|
151
|
+
const textElement = this.createBlock(blockId, part);
|
|
152
|
+
splitedParts.push(textElement);
|
|
153
|
+
});
|
|
154
|
+
element.innerHTML = parts[0];
|
|
155
|
+
element.after(...splitedParts);
|
|
156
|
+
});
|
|
157
|
+
this.addBlocks(splitedParts, updatedElements);
|
|
158
|
+
this.updateBlocks(updatedElements);
|
|
159
|
+
this.removeBlocks(removedElementsIds);
|
|
160
|
+
this.changes.clear();
|
|
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
|
+
}
|
|
181
|
+
getBlockPartObject(blockId, text) {
|
|
182
|
+
return {
|
|
183
|
+
id: blockId,
|
|
184
|
+
type: COMBINED_TEXT_BLOCK_PART,
|
|
185
|
+
data: {
|
|
186
|
+
text,
|
|
187
|
+
parentId: this.data.id,
|
|
188
|
+
parentType: COMBINED_TEXT_BLOCK_NAME
|
|
189
|
+
}
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
getMutationActions(mutationList) {
|
|
193
|
+
const updatedElements = new Set();
|
|
194
|
+
const removedElementsIds = new Set();
|
|
195
|
+
const changedOutsideElements = [];
|
|
196
|
+
this.lastBlockElement = undefined;
|
|
197
|
+
mutationList.forEach((mutation) => {
|
|
198
|
+
this.handleUpdatedBlocks(mutation, updatedElements, changedOutsideElements);
|
|
199
|
+
this.handleRemovedBlocks(mutation, removedElementsIds);
|
|
200
|
+
});
|
|
201
|
+
if (this.lastBlockElement) {
|
|
202
|
+
const lastBlockElement = this.lastBlockElement;
|
|
203
|
+
lastBlockElement.append(...changedOutsideElements);
|
|
204
|
+
this.setCaretToBlocksEnd(lastBlockElement);
|
|
205
|
+
}
|
|
206
|
+
return {
|
|
207
|
+
updatedElements,
|
|
208
|
+
removedElementsIds
|
|
209
|
+
};
|
|
210
|
+
}
|
|
211
|
+
setCaretToBlocksEnd(block) {
|
|
212
|
+
const selection = window.getSelection();
|
|
213
|
+
const range = document.createRange();
|
|
214
|
+
range.setStart(block, block.childNodes.length);
|
|
215
|
+
selection?.removeAllRanges();
|
|
216
|
+
selection?.addRange(range);
|
|
217
|
+
}
|
|
218
|
+
handleUpdatedBlocks(mutation, updatedElements, outsideChanges) {
|
|
219
|
+
let element = mutation.target;
|
|
220
|
+
if (mutation.target.nodeType === Node.TEXT_NODE) {
|
|
221
|
+
element = mutation.target.parentElement;
|
|
222
|
+
}
|
|
223
|
+
const span = element?.closest('.' + COMBINED_TEXT_BLOCK_PART);
|
|
224
|
+
if (span) {
|
|
225
|
+
updatedElements.add(span);
|
|
226
|
+
return;
|
|
227
|
+
}
|
|
228
|
+
this.handleChangesOutsideBlock(element, outsideChanges);
|
|
229
|
+
}
|
|
230
|
+
handleChangesOutsideBlock(element, outsideChanges) {
|
|
231
|
+
if (!element || this.lastBlockElement) {
|
|
232
|
+
return;
|
|
233
|
+
}
|
|
234
|
+
element.childNodes.forEach((block) => {
|
|
235
|
+
const blockElement = block;
|
|
236
|
+
if (blockElement.classList?.contains(COMBINED_TEXT_BLOCK_PART)) {
|
|
237
|
+
this.lastBlockElement = blockElement;
|
|
238
|
+
return;
|
|
239
|
+
}
|
|
240
|
+
outsideChanges.push(block);
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
addBlocks(splicedParts, updatedElements) {
|
|
244
|
+
if (!splicedParts.length) {
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
const addedBlocks = splicedParts.map((block) => {
|
|
248
|
+
const blockId = block.dataset['id'];
|
|
249
|
+
return {
|
|
250
|
+
id: blockId,
|
|
251
|
+
type: COMBINED_TEXT_BLOCK_PART,
|
|
252
|
+
data: {
|
|
253
|
+
text: block.innerHTML,
|
|
254
|
+
parentId: this.data.id,
|
|
255
|
+
parentType: COMBINED_TEXT_BLOCK_NAME
|
|
256
|
+
}
|
|
257
|
+
};
|
|
258
|
+
});
|
|
259
|
+
const previousElement = updatedElements.values().next().value;
|
|
260
|
+
const id = previousElement?.dataset['id'];
|
|
261
|
+
const index = Number(previousElement?.dataset['index']) + 1;
|
|
262
|
+
const blockIndex = this.data.textBlocks.findIndex((block) => block.id === id);
|
|
263
|
+
this.data.textBlocks.splice(blockIndex, 0, ...addedBlocks);
|
|
264
|
+
this.api.events.emit(COMBINED_TEXT_BLOCK_ADDED, {
|
|
265
|
+
index,
|
|
266
|
+
blockIndex,
|
|
267
|
+
blocks: addedBlocks,
|
|
268
|
+
data: this.data.textBlocks
|
|
269
|
+
});
|
|
270
|
+
}
|
|
271
|
+
updateBlocks(updatedElements) {
|
|
272
|
+
if (!updatedElements.size) {
|
|
273
|
+
return;
|
|
274
|
+
}
|
|
275
|
+
const updatedBlocks = [...updatedElements.values()].map((block) => {
|
|
276
|
+
return {
|
|
277
|
+
id: block.dataset['id'],
|
|
278
|
+
type: COMBINED_TEXT_BLOCK_PART,
|
|
279
|
+
data: {
|
|
280
|
+
text: block.innerHTML,
|
|
281
|
+
parentId: this.data.id,
|
|
282
|
+
parentType: COMBINED_TEXT_BLOCK_NAME
|
|
283
|
+
}
|
|
284
|
+
};
|
|
285
|
+
});
|
|
286
|
+
this.api.events.emit(COMBINED_TEXT_BLOCK_UPDATED, updatedBlocks);
|
|
287
|
+
}
|
|
288
|
+
handleRemovedBlocks(mutation, removedElementsIds) {
|
|
289
|
+
if (mutation.removedNodes.length === 0) {
|
|
290
|
+
return;
|
|
291
|
+
}
|
|
292
|
+
mutation.removedNodes.forEach((node) => {
|
|
293
|
+
if (!(node instanceof HTMLElement)) {
|
|
294
|
+
return;
|
|
295
|
+
}
|
|
296
|
+
const blockId = node.dataset['id'];
|
|
297
|
+
if (!blockId) {
|
|
298
|
+
return;
|
|
299
|
+
}
|
|
300
|
+
removedElementsIds.add(blockId);
|
|
301
|
+
});
|
|
302
|
+
}
|
|
303
|
+
removeBlocks(ids) {
|
|
304
|
+
if (!ids.size) {
|
|
305
|
+
return;
|
|
306
|
+
}
|
|
307
|
+
const removedElementIds = [...ids.values()];
|
|
308
|
+
this.data.textBlocks = this.data.textBlocks.filter((block) => !ids.has(block.id || ''));
|
|
309
|
+
this.api.events.emit(COMBINED_TEXT_BLOCK_REMOVED, removedElementIds);
|
|
310
|
+
}
|
|
311
|
+
update(blocks) {
|
|
312
|
+
if (!blocks.length) {
|
|
313
|
+
return;
|
|
314
|
+
}
|
|
315
|
+
blocks.forEach((block) => {
|
|
316
|
+
const textElement = this.createBlock(block.id || generateId(), block.data.text);
|
|
317
|
+
if (!this.wrapper) {
|
|
318
|
+
return;
|
|
319
|
+
}
|
|
320
|
+
if (this.wrapper.querySelector('.' + COMBINED_TEXT_BLOCK_PART)) {
|
|
321
|
+
this.wrapper.append(textElement);
|
|
322
|
+
return;
|
|
323
|
+
}
|
|
324
|
+
this.wrapper.replaceChildren(textElement);
|
|
325
|
+
});
|
|
326
|
+
setTimeout(() => {
|
|
327
|
+
this.api.events.emit(COMBINED_TEXT_BLOCK_ADDED, {
|
|
328
|
+
blocks
|
|
329
|
+
});
|
|
330
|
+
});
|
|
331
|
+
}
|
|
332
|
+
createBlock(id, text) {
|
|
333
|
+
const textElement = document.createElement(this.TAG);
|
|
334
|
+
textElement.classList.add(COMBINED_TEXT_BLOCK_PART);
|
|
335
|
+
textElement.innerHTML = text;
|
|
336
|
+
textElement.dataset['id'] = id;
|
|
337
|
+
return textElement;
|
|
338
|
+
}
|
|
339
|
+
convertDefaultDataToCustom(data) {
|
|
340
|
+
if (Array.isArray(data)) {
|
|
341
|
+
this.data.textBlocks = data.map((block) => {
|
|
342
|
+
block.id = generateId();
|
|
343
|
+
block.data.parentId = this.data.id;
|
|
344
|
+
return block;
|
|
345
|
+
});
|
|
346
|
+
}
|
|
347
|
+
if (!data.text) {
|
|
348
|
+
return;
|
|
349
|
+
}
|
|
350
|
+
const fragment = document.createRange().createContextualFragment(data.text);
|
|
351
|
+
let elementContent = '';
|
|
352
|
+
fragment.childNodes.forEach((node) => {
|
|
353
|
+
if (node.nodeType === Node.TEXT_NODE) {
|
|
354
|
+
elementContent += node.textContent;
|
|
355
|
+
return;
|
|
356
|
+
}
|
|
357
|
+
elementContent += node.innerHTML;
|
|
358
|
+
});
|
|
359
|
+
const parts = elementContent.length < SPLIT_MAX_LENGTH ? [elementContent] : splitHTML(elementContent);
|
|
360
|
+
parts.forEach((part) => {
|
|
361
|
+
const blockObject = this.getBlockPartObject(generateId(), part);
|
|
362
|
+
this.data.textBlocks.push(blockObject);
|
|
363
|
+
});
|
|
364
|
+
}
|
|
365
|
+
checkIsEditorEmpty() {
|
|
366
|
+
if (!this.wrapper || this.wrapper.children.length > this.MAX_CHILD_COUNT_FOR_EMPTY) {
|
|
367
|
+
return;
|
|
368
|
+
}
|
|
369
|
+
const item = this.wrapper.children.item(0);
|
|
370
|
+
const isItemEmpty = !item.textContent?.length;
|
|
371
|
+
this.wrapper.dataset['empty'] = `${isItemEmpty}`;
|
|
372
|
+
}
|
|
373
|
+
getPlaceholder(config) {
|
|
374
|
+
if (this.readOnly) {
|
|
375
|
+
return config.readonlyPlaceholder ?? DEFAULT_READONLY_PLACEHOLDER;
|
|
376
|
+
}
|
|
377
|
+
return config.placeholder ?? DEFAULT_PLACEHOLDER;
|
|
378
|
+
}
|
|
379
|
+
}
|
|
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';\r\nimport type { API, BlockTool, BlockToolConstructorOptions, ToolConfig } from '@editorjs/editorjs';\r\n\r\nimport {\r\n    COMBINED_TEXT_BLOCK,\r\n    COMBINED_TEXT_BLOCK_ADDED,\r\n    COMBINED_TEXT_BLOCK_NAME,\r\n    COMBINED_TEXT_BLOCK_PART,\r\n    COMBINED_TEXT_BLOCK_REMOVED,\r\n    COMBINED_TEXT_BLOCK_UPDATED,\r\n    DEFAULT_PLACEHOLDER,\r\n    DEFAULT_READONLY_PLACEHOLDER,\r\n    SPLIT_MAX_LENGTH\r\n} from '../constants';\r\nimport type { CuiCombinedBlockToolData, CuiCombinedPartBlock, CuiMutationActions, CuiMutationCallback } from '../interfaces';\r\nimport { recalculateIndexes, splitHTML, generateId } from '../utils';\r\n\r\nexport class CuiCombinedTextBlockTool implements BlockTool {\r\n    private readonly TAG = 'span';\r\n    private readonly DEBOUNCE_TIME = 350;\r\n    private readonly MAX_CHILD_COUNT_FOR_EMPTY = 1;\r\n    private readonly PLACEHOLDER_ATTRIBUTE_NAME = 'placeholderActive';\r\n\r\n    private mutationConfig = {\r\n        subtree: true,\r\n        childList: true,\r\n        characterData: true\r\n    };\r\n    private api: API;\r\n    private data: CuiCombinedBlockToolData;\r\n    private placeholder: string;\r\n    private wrapper?: HTMLElement;\r\n    private observer?: MutationObserver;\r\n    private lastBlockElement?: HTMLElement;\r\n    private readOnly?: boolean;\r\n    private changes = new Map();\r\n\r\n    constructor(options: unknown) {\r\n        const body = options as BlockToolConstructorOptions;\r\n        const data = body.data;\r\n\r\n        this.readOnly = body.readOnly;\r\n        this.placeholder = this.getPlaceholder(body.config);\r\n        this.api = body.api;\r\n        this.data = {\r\n            id: data.id || generateId(),\r\n            textBlocks: data.textBlocks || []\r\n        };\r\n\r\n        this.convertDefaultDataToCustom(data);\r\n    }\r\n\r\n    public static get isInline(): boolean {\r\n        return false;\r\n    }\r\n\r\n    public static get isReadOnlySupported(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public static get enableLineBreaks(): boolean {\r\n        return false;\r\n    }\r\n\r\n    public static get toolbox(): { icon: string; title: string } {\r\n        return {\r\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>',\r\n            title: 'Text'\r\n        };\r\n    }\r\n\r\n    public static get pasteConfig(): object {\r\n        return {\r\n            tags: ['P']\r\n        };\r\n    }\r\n\r\n    public onPaste(event: CustomEvent): void {\r\n        if (event.type !== 'tag') {\r\n            return;\r\n        }\r\n\r\n        const text = event.detail.data.textContent;\r\n\r\n        this.data.textBlocks.splice(this.data.textBlocks.length - 1, 1, this.getBlockPartObject(generateId(), text));\r\n        this.update(this.data.textBlocks);\r\n    }\r\n\r\n    public render(): HTMLElement {\r\n        this.wrapper = document.createElement('div');\r\n        this.wrapper.classList.add(COMBINED_TEXT_BLOCK);\r\n        this.wrapper.dataset[this.PLACEHOLDER_ATTRIBUTE_NAME] = this.api.i18n.t(this.placeholder);\r\n\r\n        if (!this.readOnly) {\r\n            this.wrapper.contentEditable = 'true';\r\n        }\r\n\r\n        if (!this.data.textBlocks.length) {\r\n            this.data.textBlocks.push(this.getBlockPartObject(generateId(), ''));\r\n        }\r\n\r\n        this.update(this.data.textBlocks);\r\n        this.checkIsEditorEmpty();\r\n\r\n        if (!this.readOnly) {\r\n            const callback = this.getMutationCallback(this.DEBOUNCE_TIME);\r\n\r\n            this.observer = new MutationObserver(this.onMutationEvent.bind(this, callback));\r\n            this.observer.observe(this.wrapper, this.mutationConfig);\r\n        }\r\n\r\n        return this.wrapper;\r\n    }\r\n\r\n    public merge(blocksData: CuiCombinedPartBlock[]): void {\r\n        if (!this.wrapper) {\r\n            return;\r\n        }\r\n\r\n        let blocksTextContent = '';\r\n        this.data.textBlocks = [];\r\n\r\n        blocksData.forEach((block) => {\r\n            blocksTextContent += block.data.text;\r\n        });\r\n\r\n        for (let i = 0; i < this.wrapper.childNodes.length; i++) {\r\n            const node = this.wrapper.childNodes.item(i);\r\n\r\n            if (!(node instanceof HTMLSpanElement)) {\r\n                return;\r\n            }\r\n\r\n            i--;\r\n            blocksTextContent = node.innerHTML + blocksTextContent;\r\n            node.remove();\r\n        }\r\n\r\n        const parts = blocksTextContent.length < SPLIT_MAX_LENGTH ? [blocksTextContent] : splitHTML(blocksTextContent);\r\n\r\n        parts.forEach((part: string) => {\r\n            const blockObject = this.getBlockPartObject(generateId(), part);\r\n\r\n            this.data.textBlocks.push(blockObject);\r\n        });\r\n\r\n        this.update(this.data.textBlocks);\r\n    }\r\n\r\n    public save(blockContent: HTMLElement): CuiCombinedPartBlock[] {\r\n        const textBlocks: CuiCombinedPartBlock[] = [];\r\n\r\n        blockContent.querySelectorAll(this.TAG).forEach((span: HTMLElement) => {\r\n            textBlocks.push(this.getBlockPartObject(span.dataset['id']!, span.innerHTML));\r\n        });\r\n\r\n        return textBlocks;\r\n    }\r\n\r\n    public removed(): void {\r\n        this.observer?.disconnect();\r\n\r\n        const blockIds = new Set<string>();\r\n\r\n        this.data.textBlocks.forEach((block: CuiCombinedPartBlock) => {\r\n            blockIds.add(block.id || '');\r\n        });\r\n\r\n        this.removeBlocks(blockIds);\r\n    }\r\n\r\n    private onMutationEvent(callback: (mutationList: MutationRecord[]) => void, mutationList: MutationRecord[]): void {\r\n        if (mutationList.length === 0) {\r\n            return;\r\n        }\r\n\r\n        mutationList.forEach((mutation) => {\r\n            if (mutation.removedNodes.length) {\r\n                this.changes.set(generateId(), mutation);\r\n\r\n                return;\r\n            }\r\n\r\n            this.changes.set(mutation.target, mutation);\r\n        });\r\n\r\n        callback(mutationList);\r\n        this.checkIsEditorEmpty();\r\n    }\r\n\r\n    private getMutationCallback = (wait: number): CuiMutationCallback => {\r\n        let timeoutId: CuiNullable<ReturnType<typeof setTimeout>> = null;\r\n\r\n        return () => {\r\n            if (timeoutId) {\r\n                clearTimeout(timeoutId);\r\n            }\r\n\r\n            timeoutId = setTimeout(() => this.handleMutations(), wait);\r\n        };\r\n    };\r\n\r\n    private handleMutations(): void {\r\n        const mutationsList = [...this.changes.values()];\r\n        const { updatedElements, removedElementsIds } = this.getMutationActions(mutationsList);\r\n        const splitedParts: HTMLElement[] = [];\r\n\r\n        updatedElements.forEach((element: HTMLElement) => {\r\n            const elementContent: string = element.innerHTML;\r\n\r\n            if (elementContent.length < SPLIT_MAX_LENGTH) {\r\n                return;\r\n            }\r\n\r\n            const parts = splitHTML(elementContent);\r\n\r\n            parts.forEach((part: string, index) => {\r\n                if (index === 0) {\r\n                    return;\r\n                }\r\n\r\n                const blockId = generateId();\r\n                const textElement = this.createBlock(blockId, part);\r\n\r\n                splitedParts.push(textElement);\r\n            });\r\n\r\n            element.innerHTML = parts[0];\r\n            element.after(...splitedParts);\r\n        });\r\n\r\n        this.addBlocks(splitedParts, updatedElements);\r\n        this.updateBlocks(updatedElements);\r\n        this.removeBlocks(removedElementsIds);\r\n        this.changes.clear();\r\n    }\r\n\r\n    private getNextIndex(): number {\r\n        recalculateIndexes(this.api.blocks);\r\n        const index = this.api.blocks.getCurrentBlockIndex();\r\n        const block = this.api.blocks.getBlockByIndex(index);\r\n        const dataIndex = Number(block?.holder.dataset['index']);\r\n\r\n        const selection = window.getSelection();\r\n        const range = selection?.rangeCount ? selection.getRangeAt(0) : null;\r\n        const caretPosition = range?.startOffset ?? 1;\r\n\r\n        let nextBlockIndex = dataIndex;\r\n\r\n        if (caretPosition !== 0) {\r\n            const blockContainer = block?.holder.querySelector('.' + COMBINED_TEXT_BLOCK) as HTMLElement;\r\n            const childrenCount = blockContainer?.children?.length ? blockContainer?.children?.length - 1 : 0;\r\n\r\n            nextBlockIndex = dataIndex + childrenCount + 1;\r\n        }\r\n\r\n        if (!nextBlockIndex) {\r\n            nextBlockIndex ||= 0;\r\n        }\r\n\r\n        return nextBlockIndex;\r\n    }\r\n\r\n    private getBlockPartObject(blockId: string, text: string): CuiCombinedPartBlock {\r\n        return {\r\n            id: blockId,\r\n            type: COMBINED_TEXT_BLOCK_PART,\r\n            data: {\r\n                text,\r\n                parentId: this.data.id,\r\n                parentType: COMBINED_TEXT_BLOCK_NAME\r\n            }\r\n        };\r\n    }\r\n\r\n    private getMutationActions(mutationList: MutationRecord[]): CuiMutationActions {\r\n        const updatedElements = new Set<HTMLElement>();\r\n        const removedElementsIds = new Set<string>();\r\n        const changedOutsideElements: Node[] = [];\r\n\r\n        this.lastBlockElement = undefined;\r\n\r\n        mutationList.forEach((mutation: MutationRecord): void => {\r\n            this.handleUpdatedBlocks(mutation, updatedElements, changedOutsideElements);\r\n            this.handleRemovedBlocks(mutation, removedElementsIds);\r\n        });\r\n\r\n        if (this.lastBlockElement) {\r\n            const lastBlockElement = this.lastBlockElement as HTMLElement;\r\n\r\n            lastBlockElement.append(...changedOutsideElements);\r\n            this.setCaretToBlocksEnd(lastBlockElement);\r\n        }\r\n\r\n        return {\r\n            updatedElements,\r\n            removedElementsIds\r\n        };\r\n    }\r\n\r\n    private setCaretToBlocksEnd(block: HTMLElement): void {\r\n        const selection = window.getSelection();\r\n        const range = document.createRange();\r\n\r\n        range.setStart(block, block.childNodes.length);\r\n        selection?.removeAllRanges();\r\n        selection?.addRange(range);\r\n    }\r\n\r\n    private handleUpdatedBlocks(\r\n        mutation: MutationRecord,\r\n        updatedElements: Set<HTMLElement>,\r\n        outsideChanges: Node[]\r\n    ): void {\r\n        let element = mutation.target as HTMLElement;\r\n\r\n        if (mutation.target.nodeType === Node.TEXT_NODE) {\r\n            element = mutation.target.parentElement as HTMLElement;\r\n        }\r\n\r\n        const span = element?.closest('.' + COMBINED_TEXT_BLOCK_PART) as HTMLElement;\r\n\r\n        if (span) {\r\n            updatedElements.add(span);\r\n\r\n            return;\r\n        }\r\n\r\n        this.handleChangesOutsideBlock(element, outsideChanges);\r\n    }\r\n\r\n    private handleChangesOutsideBlock(element: HTMLElement, outsideChanges: Node[]): void {\r\n        if (!element || this.lastBlockElement) {\r\n            return;\r\n        }\r\n\r\n        element.childNodes.forEach((block) => {\r\n            const blockElement = block as HTMLElement;\r\n\r\n            if (blockElement.classList?.contains(COMBINED_TEXT_BLOCK_PART)) {\r\n                this.lastBlockElement = blockElement;\r\n\r\n                return;\r\n            }\r\n\r\n            outsideChanges.push(block);\r\n        });\r\n    }\r\n\r\n    private addBlocks(splicedParts: HTMLElement[], updatedElements: Set<HTMLElement>): void {\r\n        if (!splicedParts.length) {\r\n            return;\r\n        }\r\n\r\n        const addedBlocks: CuiCombinedPartBlock[] = splicedParts.map((block) => {\r\n            const blockId = block.dataset['id'];\r\n\r\n            return {\r\n                id: blockId,\r\n                type: COMBINED_TEXT_BLOCK_PART,\r\n                data: {\r\n                    text: block.innerHTML,\r\n                    parentId: this.data.id,\r\n                    parentType: COMBINED_TEXT_BLOCK_NAME\r\n                }\r\n            };\r\n        });\r\n\r\n        const previousElement = updatedElements.values().next().value;\r\n        const id = previousElement?.dataset['id'];\r\n        const index = Number(previousElement?.dataset['index']) + 1;\r\n        const blockIndex = this.data.textBlocks.findIndex((block) => block.id === id);\r\n\r\n        this.data.textBlocks.splice(blockIndex, 0, ...addedBlocks);\r\n        this.api.events.emit(COMBINED_TEXT_BLOCK_ADDED, {\r\n            index,\r\n            blockIndex,\r\n            blocks: addedBlocks,\r\n            data: this.data.textBlocks\r\n        });\r\n    }\r\n\r\n    private updateBlocks(updatedElements: Set<HTMLElement>): void {\r\n        if (!updatedElements.size) {\r\n            return;\r\n        }\r\n\r\n        const updatedBlocks = [...updatedElements.values()].map((block) => {\r\n            return {\r\n                id: block.dataset['id'],\r\n                type: COMBINED_TEXT_BLOCK_PART,\r\n                data: {\r\n                    text: block.innerHTML,\r\n                    parentId: this.data.id,\r\n                    parentType: COMBINED_TEXT_BLOCK_NAME\r\n                }\r\n            };\r\n        });\r\n\r\n        this.api.events.emit(COMBINED_TEXT_BLOCK_UPDATED, updatedBlocks);\r\n    }\r\n\r\n    private handleRemovedBlocks(mutation: MutationRecord, removedElementsIds: Set<string>): void {\r\n        if (mutation.removedNodes.length === 0) {\r\n            return;\r\n        }\r\n\r\n        mutation.removedNodes.forEach((node: Node): void => {\r\n            if (!(node instanceof HTMLElement)) {\r\n                return;\r\n            }\r\n\r\n            const blockId = (node as HTMLElement).dataset['id'];\r\n\r\n            if (!blockId) {\r\n                return;\r\n            }\r\n\r\n            removedElementsIds.add(blockId);\r\n        });\r\n    }\r\n\r\n    private removeBlocks(ids: Set<string>): void {\r\n        if (!ids.size) {\r\n            return;\r\n        }\r\n\r\n        const removedElementIds = [...ids.values()];\r\n\r\n        this.data.textBlocks = this.data.textBlocks.filter((block) => !ids.has(block.id || ''));\r\n        this.api.events.emit(COMBINED_TEXT_BLOCK_REMOVED, removedElementIds);\r\n    }\r\n\r\n    private update(blocks: CuiCombinedPartBlock[]): void {\r\n        if (!blocks.length) {\r\n            return;\r\n        }\r\n\r\n        blocks.forEach((block: CuiCombinedPartBlock) => {\r\n            const textElement = this.createBlock(block.id || generateId(), block.data.text);\r\n\r\n            if (!this.wrapper) {\r\n                return;\r\n            }\r\n\r\n            if (this.wrapper.querySelector('.' + COMBINED_TEXT_BLOCK_PART)) {\r\n                this.wrapper.append(textElement);\r\n\r\n                return;\r\n            }\r\n\r\n            this.wrapper.replaceChildren(textElement);\r\n        });\r\n\r\n        setTimeout(() => {\r\n            this.api.events.emit(COMBINED_TEXT_BLOCK_ADDED, {\r\n                blocks\r\n            });\r\n        });\r\n    }\r\n\r\n    private createBlock(id: string, text: string): HTMLElement {\r\n        const textElement = document.createElement(this.TAG);\r\n        textElement.classList.add(COMBINED_TEXT_BLOCK_PART);\r\n        textElement.innerHTML = text;\r\n        textElement.dataset['id'] = id;\r\n\r\n        return textElement;\r\n    }\r\n\r\n    private convertDefaultDataToCustom(data: { text: string }): void {\r\n        if (Array.isArray(data)) {\r\n            this.data.textBlocks = data.map((block) => {\r\n                block.id = generateId();\r\n                block.data.parentId = this.data.id;\r\n\r\n                return block;\r\n            });\r\n        }\r\n\r\n        if (!data.text) {\r\n            return;\r\n        }\r\n\r\n        const fragment = document.createRange().createContextualFragment(data.text);\r\n        let elementContent = '';\r\n\r\n        fragment.childNodes.forEach((node) => {\r\n            if (node.nodeType === Node.TEXT_NODE) {\r\n                elementContent += node.textContent;\r\n\r\n                return;\r\n            }\r\n\r\n            elementContent += (node as HTMLElement).innerHTML;\r\n        });\r\n\r\n        const parts = elementContent.length < SPLIT_MAX_LENGTH ? [elementContent] : splitHTML(elementContent);\r\n\r\n        parts.forEach((part: string) => {\r\n            const blockObject = this.getBlockPartObject(generateId(), part);\r\n\r\n            this.data.textBlocks.push(blockObject);\r\n        });\r\n    }\r\n\r\n    private checkIsEditorEmpty(): void {\r\n        if (!this.wrapper || this.wrapper.children.length > this.MAX_CHILD_COUNT_FOR_EMPTY) {\r\n            return;\r\n        }\r\n\r\n        const item = this.wrapper.children.item(0) as HTMLElement;\r\n        const isItemEmpty = !item.textContent?.length;\r\n\r\n        this.wrapper.dataset['empty'] = `${isItemEmpty}`;\r\n    }\r\n\r\n    private getPlaceholder(config: ToolConfig): string {\r\n        if (this.readOnly) {\r\n            return config.readonlyPlaceholder ?? DEFAULT_READONLY_PLACEHOLDER;\r\n        }\r\n\r\n        return config.placeholder ?? DEFAULT_PLACEHOLDER;\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { MARKER_MODAL_SELECTOR } from '../components/marker-modal/marker-modal.options';
|
|
2
|
+
import { CuiMarkerTool } from './marker.tool';
|
|
3
|
+
export class CuiCustomMarkerTool extends CuiMarkerTool {
|
|
4
|
+
static get sanitize() {
|
|
5
|
+
return {
|
|
6
|
+
mark: {
|
|
7
|
+
class: true,
|
|
8
|
+
'data-id': true,
|
|
9
|
+
'data-type': true,
|
|
10
|
+
contenteditable: true
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
constructor(data) {
|
|
15
|
+
super(data);
|
|
16
|
+
}
|
|
17
|
+
wrapTool(range, markerData) {
|
|
18
|
+
const { startContainer, endContainer } = range;
|
|
19
|
+
if (markerData.data && typeof markerData.data !== 'string') {
|
|
20
|
+
this.id = markerData.data.id;
|
|
21
|
+
this.type = markerData.data.type;
|
|
22
|
+
}
|
|
23
|
+
const mark = this.createElement(markerData.title);
|
|
24
|
+
range.extractContents();
|
|
25
|
+
this.removeNestedMarkers(mark, this.DEFAULT_CLASS);
|
|
26
|
+
this.addMarkerToDOM(range, mark, startContainer, endContainer);
|
|
27
|
+
this.removeExternalMarkers(range, this.DEFAULT_CLASS);
|
|
28
|
+
this.removeEmptyMarkers(range);
|
|
29
|
+
this.api.selection.expandToTag(mark);
|
|
30
|
+
}
|
|
31
|
+
onToolButtonClick(event) {
|
|
32
|
+
const range = window.getSelection()?.getRangeAt(0);
|
|
33
|
+
if (range) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
event.stopImmediatePropagation();
|
|
37
|
+
}
|
|
38
|
+
render() {
|
|
39
|
+
super.render();
|
|
40
|
+
this.button.onclick = this.onToolButtonClick.bind(this);
|
|
41
|
+
return this.button;
|
|
42
|
+
}
|
|
43
|
+
renderActions() {
|
|
44
|
+
this.dropdown = document.createElement(this.DIV);
|
|
45
|
+
if (this.state) {
|
|
46
|
+
return this.dropdown;
|
|
47
|
+
}
|
|
48
|
+
const markerSelect = this.createLinkModal();
|
|
49
|
+
this.dropdown.append(markerSelect);
|
|
50
|
+
return this.dropdown;
|
|
51
|
+
}
|
|
52
|
+
createElement(text = '') {
|
|
53
|
+
const element = super.createElement(text);
|
|
54
|
+
element.contentEditable = 'false';
|
|
55
|
+
element.classList.add(this.CLASS);
|
|
56
|
+
element.setAttribute('data-id', this.id);
|
|
57
|
+
element.setAttribute('data-type', this.type);
|
|
58
|
+
return element;
|
|
59
|
+
}
|
|
60
|
+
checkState(select) {
|
|
61
|
+
const range = select.getRangeAt(0);
|
|
62
|
+
const mark = this.api.selection.findParentTag(this.TAG);
|
|
63
|
+
const isCorrectTool = mark?.classList.contains(this.CLASS);
|
|
64
|
+
if (!mark || !isCorrectTool) {
|
|
65
|
+
this.state = false;
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
const startContainer = range.startContainer;
|
|
69
|
+
const endContainer = range.endContainer;
|
|
70
|
+
const isStartMarker = mark.contains(startContainer);
|
|
71
|
+
const isEndMarker = mark.contains(endContainer);
|
|
72
|
+
this.state = isStartMarker && isEndMarker && isStartMarker === isEndMarker;
|
|
73
|
+
}
|
|
74
|
+
createLinkModal() {
|
|
75
|
+
this.markerModal = document.createElement(MARKER_MODAL_SELECTOR);
|
|
76
|
+
this.markerModal.tool = { id: '', title: '', type: undefined };
|
|
77
|
+
this.markerModal.target = this.button;
|
|
78
|
+
this.markerModal.isTool = true;
|
|
79
|
+
this.markerModal.isGlobal = true;
|
|
80
|
+
this.markerModal.addEventListener('saveClicked', (event) => {
|
|
81
|
+
const customEvent = event;
|
|
82
|
+
const data = customEvent.detail;
|
|
83
|
+
this.wrapTool(this.range, data);
|
|
84
|
+
});
|
|
85
|
+
return this.markerModal;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-marker.tool.js","sourceRoot":"","sources":["../../../../../projects/core/editor/tools/custom-marker.tool.ts"],"names":[],"mappings":"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","sourcesContent":["import type { InlineToolConstructorOptions, SanitizerConfig } from '@editorjs/editorjs';\r\n\r\nimport type { CuiAngularElement } from '../interfaces';\r\n\r\nimport type { MarkerModalComponent, MarkerData } from '../components/marker-modal';\r\nimport { MARKER_MODAL_SELECTOR } from '../components/marker-modal/marker-modal.options';\r\n\r\nimport { CuiMarkerTool } from './marker.tool';\r\n\r\nexport class CuiCustomMarkerTool extends CuiMarkerTool {\r\n  protected id!: string;\r\n  protected type!: string;\r\n\r\n  public static get sanitize(): SanitizerConfig {\r\n    return {\r\n      mark: {\r\n        class: true,\r\n        'data-id': true,\r\n        'data-type': true,\r\n        contenteditable: true\r\n      }\r\n    };\r\n  }\r\n\r\n  constructor(data: InlineToolConstructorOptions) {\r\n    super(data);\r\n  }\r\n\r\n  public wrapTool(range: Range, markerData: MarkerData): void {\r\n    const { startContainer, endContainer } = range;\r\n\r\n    if (markerData.data && typeof markerData.data !== 'string') {\r\n      this.id = markerData.data.id!;\r\n      this.type = markerData.data.type!;\r\n    }\r\n\r\n    const mark = this.createElement(markerData.title);\r\n\r\n    range.extractContents();\r\n\r\n    this.removeNestedMarkers(mark, this.DEFAULT_CLASS);\r\n\r\n    this.addMarkerToDOM(range, mark, startContainer, endContainer);\r\n\r\n    this.removeExternalMarkers(range, this.DEFAULT_CLASS);\r\n    this.removeEmptyMarkers(range);\r\n\r\n    this.api.selection.expandToTag(mark);\r\n  }\r\n\r\n  private onToolButtonClick(event: MouseEvent): void {\r\n    const range = window.getSelection()?.getRangeAt(0);\r\n\r\n    if (range) {\r\n      return;\r\n    }\r\n\r\n    event.stopImmediatePropagation();\r\n  }\r\n\r\n  public override render(): HTMLButtonElement {\r\n    super.render();\r\n\r\n    this.button.onclick = this.onToolButtonClick.bind(this);\r\n\r\n    return this.button;\r\n  }\r\n\r\n  public renderActions(): HTMLElement {\r\n    this.dropdown = document.createElement(this.DIV);\r\n\r\n    if (this.state) {\r\n      return this.dropdown;\r\n    }\r\n\r\n    const markerSelect = this.createLinkModal();\r\n\r\n    this.dropdown.append(markerSelect);\r\n\r\n    return this.dropdown;\r\n  }\r\n\r\n  public override createElement(text = ''): HTMLElement {\r\n    const element = super.createElement(text);\r\n\r\n    element.contentEditable = 'false';\r\n    element.classList.add(this.CLASS);\r\n    element.setAttribute('data-id', this.id);\r\n    element.setAttribute('data-type', this.type);\r\n\r\n    return element;\r\n  }\r\n\r\n  public checkState(select: Selection): void {\r\n    const range = select.getRangeAt(0);\r\n    const mark = this.api.selection.findParentTag(this.TAG);\r\n    const isCorrectTool = mark?.classList.contains(this.CLASS);\r\n\r\n    if (!mark || !isCorrectTool) {\r\n      this.state = false;\r\n\r\n      return;\r\n    }\r\n\r\n    const startContainer = range.startContainer;\r\n    const endContainer = range.endContainer;\r\n\r\n    const isStartMarker = mark.contains(startContainer);\r\n    const isEndMarker = mark.contains(endContainer);\r\n\r\n    this.state = isStartMarker && isEndMarker && isStartMarker === isEndMarker;\r\n  }\r\n\r\n  private createLinkModal(): CuiAngularElement<MarkerModalComponent> {\r\n    this.markerModal = document.createElement(MARKER_MODAL_SELECTOR) as CuiAngularElement<MarkerModalComponent>;\r\n\r\n    this.markerModal.tool = { id: '', title: '', type: undefined };\r\n    this.markerModal.target = this.button;\r\n    this.markerModal.isTool = true;\r\n    this.markerModal.isGlobal = true;\r\n\r\n    this.markerModal.addEventListener('saveClicked', (event: Event) => {\r\n      const customEvent = event as CustomEvent<MarkerData>;\r\n      const data = customEvent.detail;\r\n\r\n      this.wrapTool(this.range, data);\r\n    });\r\n\r\n    return this.markerModal;\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import Header from '@editorjs/header';
|
|
2
|
+
export class CuiHeaderTool extends Header {
|
|
3
|
+
constructor(data) {
|
|
4
|
+
super(data);
|
|
5
|
+
}
|
|
6
|
+
validate() {
|
|
7
|
+
return true;
|
|
8
|
+
}
|
|
9
|
+
render() {
|
|
10
|
+
return super.render();
|
|
11
|
+
}
|
|
12
|
+
save(block) {
|
|
13
|
+
return super.save(block);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLnRvb2wuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2VkaXRvci90b29scy9oZWFkZXIudG9vbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLE1BQU0sTUFBTSxrQkFBa0IsQ0FBQztBQUV0QyxNQUFNLE9BQU8sYUFBYyxTQUFRLE1BQU07SUFDckMsWUFBWSxJQUFTO1FBQ2pCLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQixDQUFDO0lBRWUsUUFBUTtRQUNwQixPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRWUsTUFBTTtRQUNsQixPQUFPLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRWUsSUFBSSxDQUFDLEtBQXlCO1FBQzFDLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM3QixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEJsb2NrVG9vbERhdGEgfSBmcm9tICdAZWRpdG9yanMvZWRpdG9yanMnO1xyXG5pbXBvcnQgSGVhZGVyIGZyb20gJ0BlZGl0b3Jqcy9oZWFkZXInO1xyXG5cclxuZXhwb3J0IGNsYXNzIEN1aUhlYWRlclRvb2wgZXh0ZW5kcyBIZWFkZXIge1xyXG4gICAgY29uc3RydWN0b3IoZGF0YTogYW55KSB7XHJcbiAgICAgICAgc3VwZXIoZGF0YSk7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIG92ZXJyaWRlIHZhbGlkYXRlKCk6IGJvb2xlYW4ge1xyXG4gICAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBvdmVycmlkZSByZW5kZXIoKTogSFRNTEhlYWRpbmdFbGVtZW50IHtcclxuICAgICAgICByZXR1cm4gc3VwZXIucmVuZGVyKCk7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIG92ZXJyaWRlIHNhdmUoYmxvY2s6IEhUTUxIZWFkaW5nRWxlbWVudCk6IEJsb2NrVG9vbERhdGEge1xyXG4gICAgICAgIHJldHVybiBzdXBlci5zYXZlKGJsb2NrKTtcclxuICAgIH1cclxufVxyXG4iXX0=
|