@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.
Files changed (269) hide show
  1. package/components/button/button.component.d.ts +1 -1
  2. package/components/content-wrapper/content-wrapper.component.d.ts +11 -0
  3. package/components/content-wrapper/index.d.ts +1 -0
  4. package/components/empty-state/empty-state.component.d.ts +7 -0
  5. package/components/empty-state/index.d.ts +1 -0
  6. package/components/ghost-input/ghost-input.component.d.ts +6 -0
  7. package/components/ghost-input/index.d.ts +1 -0
  8. package/components/index.d.ts +3 -0
  9. package/components/sidebar/sidebar-header/sidebar-header.component.d.ts +1 -1
  10. package/components/sidebar/sidebar-navigation-item/sidebar-navigation-item.component.d.ts +1 -1
  11. package/directives/tooltip/tooltip.component.d.ts +1 -1
  12. package/editor/components/editor-attaches-tool/editor-attaches-tool.component.d.ts +44 -0
  13. package/editor/components/editor-attaches-tool/editor-attaches-tool.options.d.ts +17 -0
  14. package/editor/components/editor-attaches-tool/index.d.ts +2 -0
  15. package/editor/components/editor-image-tool/editor-image-tool.component.d.ts +14 -0
  16. package/editor/components/editor-image-tool/editor-image-tool.options.d.ts +26 -0
  17. package/editor/components/editor-image-tool/index.d.ts +2 -0
  18. package/editor/components/editor-tool/editor-tool.component.d.ts +22 -0
  19. package/editor/components/editor-tool-modal/editor-tool-modal.component.d.ts +24 -0
  20. package/editor/components/editor-tool-modal/editor-tool-modal.options.d.ts +8 -0
  21. package/editor/components/editor-tool-modal/index.d.ts +2 -0
  22. package/editor/components/editor-tooltip/editor-tooltip.component.d.ts +16 -0
  23. package/editor/components/editor-tooltip/editor-tooltip.options.d.ts +9 -0
  24. package/editor/components/editor-tooltip/index.d.ts +2 -0
  25. package/editor/components/editor-video-tool/editor-video-tool.component.d.ts +12 -0
  26. package/editor/components/editor-video-tool/editor-video-tool.options.d.ts +26 -0
  27. package/editor/components/editor-video-tool/index.d.ts +2 -0
  28. package/editor/components/index.d.ts +7 -0
  29. package/editor/components/marker-modal/index.d.ts +3 -0
  30. package/editor/components/marker-modal/marker-modal.component.d.ts +62 -0
  31. package/editor/components/marker-modal/marker-modal.interfaces.d.ts +7 -0
  32. package/editor/components/marker-modal/marker-modal.options.d.ts +1 -0
  33. package/editor/components/marker-select/component/select-item/select-option.component.d.ts +7 -0
  34. package/editor/components/marker-select/index.d.ts +2 -0
  35. package/editor/components/marker-select/marker-select.component.d.ts +40 -0
  36. package/editor/components/marker-select/marker-select.options.d.ts +1 -0
  37. package/editor/config/custom-elements.d.ts +2 -0
  38. package/editor/config/editor.config.d.ts +3 -0
  39. package/editor/config/editor.provider.d.ts +2 -0
  40. package/editor/config/index.d.ts +2 -0
  41. package/editor/constants/editor.constants.d.ts +15 -0
  42. package/editor/constants/index.d.ts +1 -0
  43. package/editor/editor.component.d.ts +71 -0
  44. package/editor/events/editor-drag.event.d.ts +2 -0
  45. package/editor/events/editor-keyboard.event.d.ts +2 -0
  46. package/editor/events/editor-modal.event.d.ts +3 -0
  47. package/editor/events/editor-tooltip.event.d.ts +2 -0
  48. package/editor/events/set-editor-events.d.ts +1 -0
  49. package/editor/index.d.ts +9 -0
  50. package/editor/interfaces/angular-element.d.ts +2 -0
  51. package/editor/interfaces/blocks-request-data.d.ts +6 -0
  52. package/editor/interfaces/combined-block-adding-event.d.ts +7 -0
  53. package/editor/interfaces/combined-block-data.d.ts +5 -0
  54. package/editor/interfaces/combined-part-block-data.d.ts +7 -0
  55. package/editor/interfaces/custom-element.d.ts +5 -0
  56. package/editor/interfaces/event-action-data.d.ts +5 -0
  57. package/editor/interfaces/file-response-data.d.ts +10 -0
  58. package/editor/interfaces/full-block-data.d.ts +8 -0
  59. package/editor/interfaces/index.d.ts +14 -0
  60. package/editor/interfaces/main-editor-config.d.ts +15 -0
  61. package/editor/interfaces/mutation-actions.d.ts +5 -0
  62. package/editor/interfaces/parent.d.ts +4 -0
  63. package/editor/interfaces/tools.d.ts +4 -0
  64. package/editor/interfaces/tune.d.ts +6 -0
  65. package/editor/pipes/file-size.pipe.d.ts +9 -0
  66. package/editor/services/editor-service.options.d.ts +8 -0
  67. package/editor/services/editor.service.d.ts +23 -0
  68. package/editor/services/index.d.ts +6 -0
  69. package/editor/services/jtext-api.options.d.ts +20 -0
  70. package/editor/services/jtext-api.service.d.ts +23 -0
  71. package/editor/services/markers-service.options.d.ts +4 -0
  72. package/editor/services/markers.service.d.ts +11 -0
  73. package/editor/tools/attaches.tool.d.ts +28 -0
  74. package/editor/tools/bold.tool.d.ts +11 -0
  75. package/editor/tools/combined-text-block.tool.d.ts +49 -0
  76. package/editor/tools/custom-marker.tool.d.ts +16 -0
  77. package/editor/tools/header.tool.d.ts +8 -0
  78. package/editor/tools/image.tool.d.ts +37 -0
  79. package/editor/tools/index.d.ts +11 -0
  80. package/editor/tools/italic.tool.d.ts +12 -0
  81. package/editor/tools/link-marker.tool.d.ts +15 -0
  82. package/editor/tools/list.tool.d.ts +5 -0
  83. package/editor/tools/marker.tool.d.ts +36 -0
  84. package/editor/tools/role-marker.tool.d.ts +7 -0
  85. package/editor/tools/selection-base.tool.d.ts +24 -0
  86. package/editor/tools/tool-marker.tool.d.ts +7 -0
  87. package/editor/tools/video.tool.d.ts +32 -0
  88. package/editor/utils/create-link-modal.d.ts +3 -0
  89. package/editor/utils/create-tool-modal.d.ts +4 -0
  90. package/editor/utils/create-tooltip.d.ts +8 -0
  91. package/editor/utils/file-uploader.d.ts +26 -0
  92. package/editor/utils/generate-id.d.ts +1 -0
  93. package/editor/utils/index.d.ts +9 -0
  94. package/editor/utils/recalculate-indexes.d.ts +2 -0
  95. package/editor/utils/remove-element-tag-wrapper.d.ts +1 -0
  96. package/editor/utils/split-html.d.ts +1 -0
  97. package/editor/utils/url.validator.d.ts +2 -0
  98. package/editor/widgets/editor-block/editor-block.component.d.ts +22 -0
  99. package/editor/widgets/editor-block/index.d.ts +1 -0
  100. package/editor/widgets/editor-modal/editor-modal.component.d.ts +19 -0
  101. package/editor/widgets/editor-modal/index.d.ts +1 -0
  102. package/editor/widgets/editor-readonly/editor-readonly.component.d.ts +28 -0
  103. package/editor/widgets/editor-readonly/editor-readonly.options.d.ts +5 -0
  104. package/editor/widgets/editor-readonly/index.d.ts +2 -0
  105. package/editor/widgets/index.d.ts +3 -0
  106. package/esm2022/components/breadcrumbs/breadcrumbs.component.mjs +2 -2
  107. package/esm2022/components/content-wrapper/content-wrapper.component.mjs +29 -0
  108. package/esm2022/components/content-wrapper/index.mjs +2 -0
  109. package/esm2022/components/empty-state/empty-state.component.mjs +17 -0
  110. package/esm2022/components/empty-state/index.mjs +2 -0
  111. package/esm2022/components/ghost-input/ghost-input.component.mjs +16 -0
  112. package/esm2022/components/ghost-input/index.mjs +2 -0
  113. package/esm2022/components/index.mjs +4 -1
  114. package/esm2022/directives/tooltip/tooltip-describe.directive.mjs +5 -3
  115. package/esm2022/directives/tooltip/tooltip-position.directive.mjs +6 -3
  116. package/esm2022/directives/tooltip/tooltip.component.mjs +6 -3
  117. package/esm2022/editor/components/editor-attaches-tool/editor-attaches-tool.component.mjs +76 -0
  118. package/esm2022/editor/components/editor-attaches-tool/editor-attaches-tool.options.mjs +2 -0
  119. package/esm2022/editor/components/editor-attaches-tool/index.mjs +3 -0
  120. package/esm2022/editor/components/editor-image-tool/editor-image-tool.component.mjs +43 -0
  121. package/esm2022/editor/components/editor-image-tool/editor-image-tool.options.mjs +2 -0
  122. package/esm2022/editor/components/editor-image-tool/index.mjs +3 -0
  123. package/esm2022/editor/components/editor-tool/editor-tool.component.mjs +74 -0
  124. package/esm2022/editor/components/editor-tool-modal/editor-tool-modal.component.mjs +69 -0
  125. package/esm2022/editor/components/editor-tool-modal/editor-tool-modal.options.mjs +2 -0
  126. package/esm2022/editor/components/editor-tool-modal/index.mjs +3 -0
  127. package/esm2022/editor/components/editor-tooltip/editor-tooltip.component.mjs +45 -0
  128. package/esm2022/editor/components/editor-tooltip/editor-tooltip.options.mjs +2 -0
  129. package/esm2022/editor/components/editor-tooltip/index.mjs +3 -0
  130. package/esm2022/editor/components/editor-video-tool/editor-video-tool.component.mjs +41 -0
  131. package/esm2022/editor/components/editor-video-tool/editor-video-tool.options.mjs +2 -0
  132. package/esm2022/editor/components/editor-video-tool/index.mjs +3 -0
  133. package/esm2022/editor/components/index.mjs +8 -0
  134. package/esm2022/editor/components/marker-modal/index.mjs +3 -0
  135. package/esm2022/editor/components/marker-modal/marker-modal.component.mjs +261 -0
  136. package/esm2022/editor/components/marker-modal/marker-modal.interfaces.mjs +2 -0
  137. package/esm2022/editor/components/marker-modal/marker-modal.options.mjs +2 -0
  138. package/esm2022/editor/components/marker-select/component/select-item/select-option.component.mjs +15 -0
  139. package/esm2022/editor/components/marker-select/index.mjs +3 -0
  140. package/esm2022/editor/components/marker-select/marker-select.component.mjs +155 -0
  141. package/esm2022/editor/components/marker-select/marker-select.options.mjs +2 -0
  142. package/esm2022/editor/config/custom-elements.mjs +32 -0
  143. package/esm2022/editor/config/editor.config.mjs +30 -0
  144. package/esm2022/editor/config/editor.provider.mjs +19 -0
  145. package/esm2022/editor/config/index.mjs +3 -0
  146. package/esm2022/editor/constants/editor.constants.mjs +20 -0
  147. package/esm2022/editor/constants/index.mjs +2 -0
  148. package/esm2022/editor/editor.component.mjs +380 -0
  149. package/esm2022/editor/events/editor-drag.event.mjs +7 -0
  150. package/esm2022/editor/events/editor-keyboard.event.mjs +33 -0
  151. package/esm2022/editor/events/editor-modal.event.mjs +31 -0
  152. package/esm2022/editor/events/editor-tooltip.event.mjs +63 -0
  153. package/esm2022/editor/events/set-editor-events.mjs +11 -0
  154. package/esm2022/editor/i18n/en.json +14 -0
  155. package/esm2022/editor/index.mjs +8 -0
  156. package/esm2022/editor/interfaces/angular-element.mjs +2 -0
  157. package/esm2022/editor/interfaces/blocks-request-data.mjs +2 -0
  158. package/esm2022/editor/interfaces/combined-block-adding-event.mjs +2 -0
  159. package/esm2022/editor/interfaces/combined-block-data.mjs +2 -0
  160. package/esm2022/editor/interfaces/combined-part-block-data.mjs +2 -0
  161. package/esm2022/editor/interfaces/custom-element.mjs +2 -0
  162. package/esm2022/editor/interfaces/event-action-data.mjs +2 -0
  163. package/esm2022/editor/interfaces/file-response-data.mjs +2 -0
  164. package/esm2022/editor/interfaces/full-block-data.mjs +2 -0
  165. package/esm2022/editor/interfaces/index.mjs +14 -0
  166. package/esm2022/editor/interfaces/main-editor-config.mjs +2 -0
  167. package/esm2022/editor/interfaces/mutation-actions.mjs +2 -0
  168. package/esm2022/editor/interfaces/parent.mjs +2 -0
  169. package/esm2022/editor/interfaces/tools.mjs +2 -0
  170. package/esm2022/editor/interfaces/tune.mjs +2 -0
  171. package/esm2022/editor/pipes/file-size.pipe.mjs +25 -0
  172. package/esm2022/editor/services/editor-service.options.mjs +4 -0
  173. package/esm2022/editor/services/editor.service.mjs +138 -0
  174. package/esm2022/editor/services/index.mjs +7 -0
  175. package/esm2022/editor/services/jtext-api.options.mjs +2 -0
  176. package/esm2022/editor/services/jtext-api.service.mjs +50 -0
  177. package/esm2022/editor/services/markers-service.options.mjs +2 -0
  178. package/esm2022/editor/services/markers.service.mjs +79 -0
  179. package/esm2022/editor/tools/attaches.tool.mjs +96 -0
  180. package/esm2022/editor/tools/bold.tool.mjs +33 -0
  181. package/esm2022/editor/tools/combined-text-block.tool.mjs +380 -0
  182. package/esm2022/editor/tools/custom-marker.tool.mjs +88 -0
  183. package/esm2022/editor/tools/header.tool.mjs +16 -0
  184. package/esm2022/editor/tools/image.tool.mjs +157 -0
  185. package/esm2022/editor/tools/index.mjs +12 -0
  186. package/esm2022/editor/tools/italic.tool.mjs +35 -0
  187. package/esm2022/editor/tools/link-marker.tool.mjs +80 -0
  188. package/esm2022/editor/tools/list.tool.mjs +10 -0
  189. package/esm2022/editor/tools/marker.tool.mjs +144 -0
  190. package/esm2022/editor/tools/role-marker.tool.mjs +17 -0
  191. package/esm2022/editor/tools/selection-base.tool.mjs +92 -0
  192. package/esm2022/editor/tools/tool-marker.tool.mjs +14 -0
  193. package/esm2022/editor/tools/video.tool.mjs +132 -0
  194. package/esm2022/editor/utils/create-link-modal.mjs +22 -0
  195. package/esm2022/editor/utils/create-tool-modal.mjs +45 -0
  196. package/esm2022/editor/utils/create-tooltip.mjs +44 -0
  197. package/esm2022/editor/utils/file-uploader.mjs +57 -0
  198. package/esm2022/editor/utils/generate-id.mjs +4 -0
  199. package/esm2022/editor/utils/index.mjs +10 -0
  200. package/esm2022/editor/utils/recalculate-indexes.mjs +32 -0
  201. package/esm2022/editor/utils/remove-element-tag-wrapper.mjs +11 -0
  202. package/esm2022/editor/utils/split-html.mjs +128 -0
  203. package/esm2022/editor/utils/url.validator.mjs +12 -0
  204. package/esm2022/editor/widgets/editor-block/editor-block.component.mjs +63 -0
  205. package/esm2022/editor/widgets/editor-block/index.mjs +2 -0
  206. package/esm2022/editor/widgets/editor-modal/editor-modal.component.mjs +47 -0
  207. package/esm2022/editor/widgets/editor-modal/index.mjs +2 -0
  208. package/esm2022/editor/widgets/editor-readonly/editor-readonly.component.mjs +40 -0
  209. package/esm2022/editor/widgets/editor-readonly/editor-readonly.options.mjs +2 -0
  210. package/esm2022/editor/widgets/editor-readonly/index.mjs +2 -0
  211. package/esm2022/editor/widgets/index.mjs +4 -0
  212. package/esm2022/index.mjs +3 -1
  213. package/esm2022/interceptors/loader.interceptor.mjs +3 -3
  214. package/esm2022/services/loader.options.mjs +2 -2
  215. package/esm2022/services/loader.service.mjs +11 -11
  216. package/esm2022/utils/default-validators/create-default-validators.mjs +12 -0
  217. package/esm2022/utils/default-validators/extra-spaces.options.mjs +11 -0
  218. package/esm2022/utils/default-validators/extra-spaces.validators.mjs +16 -0
  219. package/esm2022/utils/default-validators/index.mjs +2 -0
  220. package/esm2022/utils/index.mjs +2 -1
  221. package/esm2022/widgets/categories/categories.component.mjs +75 -0
  222. package/esm2022/widgets/categories/components/categories-list/categories-list.component.mjs +16 -0
  223. package/esm2022/widgets/categories/components/categories-list/index.mjs +2 -0
  224. package/esm2022/widgets/categories/components/category-form/category-form.component.mjs +79 -0
  225. package/esm2022/widgets/categories/components/category-form/index.mjs +2 -0
  226. package/esm2022/widgets/categories/components/category-item/category-item.component.mjs +123 -0
  227. package/esm2022/widgets/categories/components/category-item/index.mjs +2 -0
  228. package/esm2022/widgets/categories/components/create-category-item/create-category-item.component.mjs +25 -0
  229. package/esm2022/widgets/categories/components/create-category-item/index.mjs +2 -0
  230. package/esm2022/widgets/categories/components/index.mjs +3 -0
  231. package/esm2022/widgets/categories/index.mjs +2 -0
  232. package/esm2022/widgets/categories/services/index.mjs +2 -0
  233. package/esm2022/widgets/categories/services/selected-category.service.mjs +38 -0
  234. package/esm2022/widgets/general-control-error-hint/general-control-error-hint.component.mjs +21 -0
  235. package/esm2022/widgets/general-control-error-hint/index.mjs +2 -0
  236. package/esm2022/widgets/index.mjs +3 -0
  237. package/esm2022/widgets/utility-info/index.mjs +2 -0
  238. package/esm2022/widgets/utility-info/utility-info.component.mjs +224 -0
  239. package/fesm2022/cuby-ui-core-en-D3DnyYmu.mjs +29 -0
  240. package/fesm2022/cuby-ui-core-en-D3DnyYmu.mjs.map +1 -0
  241. package/fesm2022/cuby-ui-core.mjs +4047 -67
  242. package/fesm2022/cuby-ui-core.mjs.map +1 -1
  243. package/index.d.ts +2 -0
  244. package/package.json +3 -3
  245. package/services/loader.options.d.ts +2 -2
  246. package/services/loader.service.d.ts +7 -7
  247. package/utils/default-validators/create-default-validators.d.ts +5 -0
  248. package/utils/default-validators/extra-spaces.options.d.ts +2 -0
  249. package/utils/default-validators/extra-spaces.validators.d.ts +3 -0
  250. package/utils/default-validators/index.d.ts +1 -0
  251. package/utils/index.d.ts +1 -0
  252. package/widgets/categories/categories.component.d.ts +24 -0
  253. package/widgets/categories/components/categories-list/categories-list.component.d.ts +7 -0
  254. package/widgets/categories/components/categories-list/index.d.ts +1 -0
  255. package/widgets/categories/components/category-form/category-form.component.d.ts +28 -0
  256. package/widgets/categories/components/category-form/index.d.ts +1 -0
  257. package/widgets/categories/components/category-item/category-item.component.d.ts +40 -0
  258. package/widgets/categories/components/category-item/index.d.ts +1 -0
  259. package/widgets/categories/components/create-category-item/create-category-item.component.d.ts +10 -0
  260. package/widgets/categories/components/create-category-item/index.d.ts +1 -0
  261. package/widgets/categories/components/index.d.ts +2 -0
  262. package/widgets/categories/index.d.ts +1 -0
  263. package/widgets/categories/services/index.d.ts +1 -0
  264. package/widgets/categories/services/selected-category.service.d.ts +18 -0
  265. package/widgets/general-control-error-hint/general-control-error-hint.component.d.ts +9 -0
  266. package/widgets/general-control-error-hint/index.d.ts +1 -0
  267. package/widgets/index.d.ts +2 -0
  268. package/widgets/utility-info/index.d.ts +1 -0
  269. 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=