@talrace/ngx-noder 0.0.8 → 0.0.9

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 (93) hide show
  1. package/esm2022/lib/apart-components/add-link-dialog/add-link-dialog.component.mjs +15 -9
  2. package/esm2022/lib/apart-components/editor-toolbar/components/base-toolbar.component.mjs +8 -2
  3. package/esm2022/lib/apart-components/editor-toolbar/components/buttons/font/font.component.mjs +2 -2
  4. package/esm2022/lib/apart-components/editor-toolbar/components/buttons/font-size/font-size.component.mjs +3 -3
  5. package/esm2022/lib/apart-components/editor-toolbar/shared/toolbar-styles.helper.mjs +1 -8
  6. package/esm2022/lib/editor/components/edges/edge.component.mjs +2 -2
  7. package/esm2022/lib/editor/components/edges/edges.mjs +21 -2
  8. package/esm2022/lib/editor/components/image/input-handler/image-input.handler.mjs +18 -1
  9. package/esm2022/lib/editor/components/shared/services/custom-content.service.mjs +22 -56
  10. package/esm2022/lib/editor/components/table/components/table-cell.component.mjs +6 -6
  11. package/esm2022/lib/editor/components/table/components/table.component.mjs +13 -4
  12. package/esm2022/lib/editor/components/table/models/cell-data.model.mjs +3 -4
  13. package/esm2022/lib/editor/components/table/selection/table-selection.mjs +15 -5
  14. package/esm2022/lib/editor/content/constants/editor.const.mjs +9 -1
  15. package/esm2022/lib/editor/content/display-data/display-data.mjs +839 -0
  16. package/esm2022/lib/editor/content/display-data/general-properties.model.mjs +1 -1
  17. package/esm2022/lib/editor/content/display-data/models/paragraph-info.model.mjs +8 -0
  18. package/esm2022/lib/editor/content/display-data/paragraph.mjs +5 -1
  19. package/esm2022/lib/editor/content/display-data/text-line-info.mjs +2 -1
  20. package/esm2022/lib/editor/content/display-data/toolbar-styles.interface.mjs +1 -1
  21. package/esm2022/lib/editor/content/helpers/content-style.helper.mjs +12 -30
  22. package/esm2022/lib/editor/content/helpers/display-token.helper.mjs +62 -0
  23. package/esm2022/lib/editor/display/layers/cursor.layer.mjs +9 -8
  24. package/esm2022/lib/editor/display/layers/pages.layer.mjs +5 -5
  25. package/esm2022/lib/editor/display/layers/print.text.layer.mjs +2 -2
  26. package/esm2022/lib/editor/display/layers/selection.layer.mjs +15 -9
  27. package/esm2022/lib/editor/display/layers/text.layer.mjs +25 -27
  28. package/esm2022/lib/editor/display/print/print.renderer.mjs +8 -8
  29. package/esm2022/lib/editor/display/renderer.mjs +10 -10
  30. package/esm2022/lib/editor/display/rendering.helper.mjs +2 -4
  31. package/esm2022/lib/editor/display/virtual.renderer.mjs +5 -5
  32. package/esm2022/lib/editor/execution/edit.session.mjs +199 -755
  33. package/esm2022/lib/editor/execution/editor.mjs +116 -75
  34. package/esm2022/lib/editor/execution/helpers/format-style.helper.mjs +1 -33
  35. package/esm2022/lib/editor/execution/helpers/image.helpet.mjs +12 -0
  36. package/esm2022/lib/editor/execution/helpers/paragraph.helper.mjs +11 -3
  37. package/esm2022/lib/editor/execution/regulator.service.mjs +28 -20
  38. package/esm2022/lib/editor/gadgets/numbering/numbering-paragraph-style.model.mjs +13 -0
  39. package/esm2022/lib/editor/gadgets/numbering/numbering.helper.mjs +77 -10
  40. package/esm2022/lib/editor/gadgets/search/search.mjs +6 -6
  41. package/esm2022/lib/editor/interaction/editor.service.mjs +27 -6
  42. package/esm2022/lib/editor/interaction/input.handler.mjs +8 -5
  43. package/esm2022/lib/editor/interaction/mouse.handler.mjs +2 -1
  44. package/esm2022/lib/editor/operations/helpers/format-operations.helper.mjs +32 -2
  45. package/esm2022/lib/editor/operations/helpers/link-operations.helper.mjs +47 -12
  46. package/esm2022/lib/editor/operations/operations-helper.helper.mjs +13 -14
  47. package/esm2022/lib/editor/operations/save-commands.helper.mjs +2 -2
  48. package/esm2022/lib/editor/positioning/content.helper.mjs +15 -15
  49. package/esm2022/lib/editor/positioning/line-width.helper.mjs +5 -5
  50. package/esm2022/lib/editor/positioning/position.helper.mjs +34 -32
  51. package/esm2022/lib/editor/positioning/selection.mjs +42 -32
  52. package/esm2022/lib/editor/revision.helper.mjs +4 -3
  53. package/fesm2022/talrace-ngx-noder.mjs +3765 -3548
  54. package/fesm2022/talrace-ngx-noder.mjs.map +1 -1
  55. package/lib/apart-components/add-link-dialog/add-link-dialog.component.d.ts +0 -1
  56. package/lib/apart-components/editor-toolbar/shared/toolbar-styles.helper.d.ts +0 -2
  57. package/lib/editor/components/image/input-handler/image-input.handler.d.ts +3 -0
  58. package/lib/editor/components/shared/services/custom-content.service.d.ts +3 -5
  59. package/lib/editor/components/table/components/table-cell.component.d.ts +1 -1
  60. package/lib/editor/components/table/components/table.component.d.ts +1 -0
  61. package/lib/editor/components/table/models/cell-data.model.d.ts +1 -1
  62. package/lib/editor/components/table/selection/table-selection.d.ts +2 -0
  63. package/lib/editor/content/constants/editor.const.d.ts +2 -0
  64. package/lib/editor/content/display-data/display-data.d.ts +103 -0
  65. package/lib/editor/content/display-data/general-properties.model.d.ts +5 -0
  66. package/lib/editor/content/display-data/models/paragraph-info.model.d.ts +9 -0
  67. package/lib/editor/content/display-data/paragraph.d.ts +1 -0
  68. package/lib/editor/content/display-data/text-line-info.d.ts +1 -0
  69. package/lib/editor/content/display-data/toolbar-styles.interface.d.ts +1 -1
  70. package/lib/editor/content/helpers/content-style.helper.d.ts +1 -2
  71. package/lib/editor/content/helpers/display-token.helper.d.ts +6 -0
  72. package/lib/editor/display/layers/text.layer.d.ts +1 -2
  73. package/lib/editor/display/print/print.renderer.d.ts +0 -2
  74. package/lib/editor/execution/edit.session.d.ts +11 -59
  75. package/lib/editor/execution/editor.d.ts +9 -6
  76. package/lib/editor/execution/helpers/format-style.helper.d.ts +0 -2
  77. package/lib/editor/execution/helpers/image.helpet.d.ts +4 -0
  78. package/lib/editor/execution/regulator.service.d.ts +1 -1
  79. package/lib/editor/gadgets/numbering/numbering-paragraph-style.model.d.ts +6 -0
  80. package/lib/editor/gadgets/numbering/numbering.helper.d.ts +10 -3
  81. package/lib/editor/interaction/editor.service.d.ts +12 -3
  82. package/lib/editor/operations/helpers/link-operations.helper.d.ts +5 -3
  83. package/lib/editor/positioning/content.helper.d.ts +6 -5
  84. package/lib/editor/positioning/position.helper.d.ts +3 -3
  85. package/lib/editor/positioning/selection.d.ts +3 -0
  86. package/package.json +1 -1
  87. package/src/_ngx-noder.theme.scss +31 -2
  88. package/esm2022/lib/editor/content/display-data/document.mjs +0 -134
  89. package/esm2022/lib/editor/content/display-data/pages.wrap.mjs +0 -226
  90. package/esm2022/lib/editor/execution/helpers/delta.helper.mjs +0 -18
  91. package/lib/editor/content/display-data/document.d.ts +0 -56
  92. package/lib/editor/content/display-data/pages.wrap.d.ts +0 -42
  93. package/lib/editor/execution/helpers/delta.helper.d.ts +0 -6
@@ -2,15 +2,13 @@ import { DistanceModel } from '../../execution/distance.model';
2
2
  import { DomHelper } from '../../execution/helpers/dom.helper';
3
3
  import { EdgeElementModel } from '../../components/edges/edge-element.model';
4
4
  import { EdgeType } from '../../components/edges/edge-type.enum';
5
- import { EventEmitting } from '../../core/event-emitting';
6
5
  import { FormatExtModel } from '../../content/display-data/format-ext.model';
7
6
  import { FormatStyleHelper } from '../../execution/helpers/format-style.helper';
8
7
  import { Lines } from '../../content/display-data/lines';
9
8
  import { ParagraphHelper } from '../../execution/helpers/paragraph.helper';
10
9
  import { RenderingHelper } from '../rendering.helper';
11
- export class TextLayer extends EventEmitting {
10
+ export class TextLayer {
12
11
  constructor(parentElement, session, editorService, renderingHelper = RenderingHelper) {
13
- super();
14
12
  this.session = session;
15
13
  this.editorService = editorService;
16
14
  this.renderingHelper = renderingHelper;
@@ -23,11 +21,11 @@ export class TextLayer extends EventEmitting {
23
21
  this.element.className = 'noder-layer noder-text-layer';
24
22
  parentElement.appendChild(this.element);
25
23
  this.lines = new Lines(this.element);
26
- this.session.pagesWrap.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);
27
- this.element.style.width = `${this.session.pagesWrap.pageWidth}px`;
24
+ this.session.displayData.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);
25
+ this.element.style.width = `${this.session.displayData.pageWidth}px`;
28
26
  }
29
27
  destroy() {
30
- this.session.pagesWrap.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);
28
+ this.session.displayData.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);
31
29
  }
32
30
  updateEdges(config) {
33
31
  DomHelper.translate(this.element, 0, -config.scrollTop);
@@ -97,14 +95,14 @@ export class TextLayer extends EventEmitting {
97
95
  }
98
96
  }
99
97
  getEdgeParagraphTop(topOffset, page) {
100
- const paragraphTop = this.session.pagesWrap.pagesSpace + topOffset;
101
- return paragraphTop + (page - 1) * (this.session.pagesWrap.pageHeight + this.session.pagesWrap.pagesSpace);
98
+ const paragraphTop = this.session.displayData.pagesSpace + topOffset;
99
+ return paragraphTop + (page - 1) * (this.session.displayData.pageHeight + this.session.displayData.pagesSpace);
102
100
  }
103
101
  getParagraphTop(row) {
104
- return this.session.pagesWrap.getParagraphTop(row);
102
+ return this.session.displayData.getDistanceFromTop(row);
105
103
  }
106
104
  renderPagesEdgeComponents(pages) {
107
- const pagesWrap = this.session.pagesWrap;
105
+ const displayData = this.session.displayData;
108
106
  for (let page of pages) {
109
107
  const header = this.session.customComponents.edges.getComponentByPage(page, EdgeType.Header);
110
108
  const headerHeight = this.session.customComponents.edges.getComponentHeight(page, EdgeType.Header);
@@ -114,7 +112,7 @@ export class TextLayer extends EventEmitting {
114
112
  const footer = this.session.customComponents.edges.getComponentByPage(page, EdgeType.Footer);
115
113
  const footerHeight = this.session.customComponents.edges.getComponentHeight(page, EdgeType.Footer);
116
114
  if (footer) {
117
- const topOffset = pagesWrap.pageHeight - footerHeight;
115
+ const topOffset = displayData.pageHeight - footerHeight;
118
116
  this.renderEdgeComponent(footer, footerHeight, page, topOffset);
119
117
  }
120
118
  }
@@ -154,15 +152,15 @@ export class TextLayer extends EventEmitting {
154
152
  const paragraphCell = this.lines.createCell(row);
155
153
  paragraphCell.element.className = 'noder-line-group';
156
154
  DomHelper.removeChildren(paragraphCell.element);
157
- const paragraphHeight = this.session.pagesWrap.getParagraphHeight(row);
155
+ const paragraphHeight = this.session.displayData.getParagraphHeight(row);
158
156
  const paragraphTop = this.getParagraphTop(row);
159
157
  DomHelper.setStyle(paragraphCell.element.style, 'height', `${paragraphHeight}px`);
160
158
  DomHelper.setStyle(paragraphCell.element.style, 'top', `${paragraphTop}px`);
161
- DomHelper.setStyle(paragraphCell.element.style, 'padding-left', `${this.session.pagesWrap.documentMargin.left}px`);
162
- DomHelper.setStyle(paragraphCell.element.style, 'padding-right', `${this.session.pagesWrap.documentMargin.right}px`);
163
- const paragraph = this.session.pagesWrap.paragraphs[row];
164
- if (paragraph.numberingData.numberingId !== null) {
165
- const numberingElement = this.renderingHelper.renderNumberingMarker(paragraph, this.element, this.session.generalProperties.scalingRatio);
159
+ DomHelper.setStyle(paragraphCell.element.style, 'padding-left', `${this.session.displayData.pageMargin.left}px`);
160
+ DomHelper.setStyle(paragraphCell.element.style, 'padding-right', `${this.session.displayData.pageMargin.right}px`);
161
+ const paragraphSettings = this.session.displayData.getParagraphSettings(row);
162
+ if (paragraphSettings?.numberingData.numberingId !== null) {
163
+ const numberingElement = this.renderingHelper.renderNumberingMarker(paragraphSettings, this.element, this.session.generalProperties.scalingRatio);
166
164
  numberingElement.className = 'numberingMarker';
167
165
  paragraphCell.element.appendChild(numberingElement);
168
166
  }
@@ -173,31 +171,31 @@ export class TextLayer extends EventEmitting {
173
171
  }
174
172
  renderTextLines(parent, row) {
175
173
  const linesContainerElement = this.renderingHelper.createDivContainer('lines-container');
176
- const currentParagraph = this.session.pagesWrap.paragraphs[row];
177
- const paragraphHeight = ParagraphHelper.getParagraphHeight(currentParagraph.textLinesInfo);
174
+ const paragraphSettings = this.session.displayData.getParagraphSettings(row);
175
+ const paragraphHeight = ParagraphHelper.getParagraphHeight(paragraphSettings.textLinesInfo);
178
176
  DomHelper.setStyle(linesContainerElement.style, 'height', `${paragraphHeight}px`);
179
177
  parent.appendChild(linesContainerElement);
180
- const startIndex = this.session.document.positionToIndex({ row, column: 0 });
181
- const endIndex = this.session.document.positionToIndex({ row: row + 1, column: 0 }) - 1;
178
+ const startIndex = this.session.displayData.positionToIndex({ row, column: 0 });
179
+ const endIndex = this.session.displayData.positionToIndex({ row: row + 1, column: 0 }) - 1;
182
180
  const formats = FormatStyleHelper.getFormatsAtRange(this.session.model.formats, startIndex, endIndex);
183
- const splits = this.session.wrapData[row];
181
+ const splits = this.session.displayData.paragraphs[row].nextLineIndexes;
184
182
  const formatsExt = formats.map(format => new FormatExtModel({
185
183
  ...format,
186
184
  content: this.session.model.content.substring(format.startIndex, format.endIndex + 1)
187
185
  }));
188
186
  if (splits?.length) {
189
187
  const distance = new DistanceModel({ start: startIndex, end: endIndex });
190
- this.renderingHelper.renderContentWrappedLine({ currentElement: this.element, parentNode: linesContainerElement }, splits, currentParagraph, formatsExt, distance, this.session.customContentService, this.session.customComponents, this.session.generalProperties.scalingRatio, this.session.model.breaks);
188
+ this.renderingHelper.renderContentWrappedLine({ currentElement: this.element, parentNode: linesContainerElement }, splits, paragraphSettings, formatsExt, distance, this.session.customContentService, this.session.customComponents, this.session.generalProperties.scalingRatio, this.session.model.breaks);
191
189
  }
192
190
  else {
193
- const numberingOffsetLeft = currentParagraph.numberingData.numberingId === null
191
+ const numberingOffsetLeft = paragraphSettings.numberingData.numberingId === null
194
192
  ? 0
195
- : currentParagraph.numberingData.width + currentParagraph.numberingData.paddingLeft;
196
- const lastLineEl = this.renderingHelper.createLineElement(currentParagraph.textLinesInfo[0], numberingOffsetLeft, this.session.generalProperties.scalingRatio);
193
+ : paragraphSettings.numberingData.width + paragraphSettings.numberingData.paddingLeft;
194
+ const lastLineEl = this.renderingHelper.createLineElement(paragraphSettings.textLinesInfo[0], numberingOffsetLeft, this.session.generalProperties.scalingRatio);
197
195
  linesContainerElement.appendChild(lastLineEl);
198
196
  const rowDistance = new DistanceModel({ start: startIndex, end: endIndex });
199
197
  this.renderingHelper.renderContentSimpleLine({ currentElement: this.element, parentNode: lastLineEl }, formatsExt, rowDistance, this.session.customContentService, this.session.customComponents, this.session.model.breaks);
200
198
  }
201
199
  }
202
200
  }
203
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.layer.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/display/layers/text.layer.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, EmbeddedViewRef } from '@angular/core';\n\nimport { Cell } from '../cell.interface';\nimport { DistanceModel } from '../../execution/distance.model';\nimport { DomHelper } from '../../execution/helpers/dom.helper';\nimport { EdgeElementModel } from '../../components/edges/edge-element.model';\nimport { EdgeType } from '../../components/edges/edge-type.enum';\nimport { EditSession } from '../../execution/edit.session';\nimport { EditorService } from '../../interaction/editor.service';\nimport { EventEmitting } from '../../core/event-emitting';\nimport { FormatExtModel } from '../../content/display-data/format-ext.model';\nimport { FormatStyleHelper } from '../../execution/helpers/format-style.helper';\nimport { ILayerConfig } from './layer.config';\nimport { Lines } from '../../content/display-data/lines';\nimport { NoderEdgeComponent } from '../../components/edges/edge.component';\nimport { PageType } from '../../components/edges/page-type.enum';\nimport { ParagraphHelper } from '../../execution/helpers/paragraph.helper';\nimport { RenderingHelper } from '../rendering.helper';\n\nexport class TextLayer extends EventEmitting {\n    element: HTMLElement;\n\n    lines: Lines;\n\n    config: ILayerConfig;\n\n    edgeElements: EdgeElementModel[] = [];\n\n    edgeEditingPage: number | null = null;\n\n    constructor(\n        parentElement: HTMLElement,\n        protected session: EditSession,\n        private editorService: EditorService,\n        private renderingHelper = RenderingHelper\n    ) {\n        super();\n\n        this.element = document.createElement('div');\n        this.element.className = 'noder-layer noder-text-layer';\n        parentElement.appendChild(this.element);\n\n        this.lines = new Lines(this.element);\n\n        this.session.pagesWrap.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n        this.element.style.width = `${this.session.pagesWrap.pageWidth}px`;\n    }\n\n    destroy(): void {\n        this.session.pagesWrap.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n    }\n\n    updateEdges(config: ILayerConfig): void {\n        DomHelper.translate(this.element, 0, -config.scrollTop);\n        while (this.edgeElements.length) {\n            const removedEl = this.edgeElements.pop();\n            DomHelper.removeElement(removedEl.element);\n        }\n\n        this.renderPagesEdgeComponents(config.pages);\n    }\n\n    edgeEditingPageUpdated(page: number | null): void {\n        this.edgeEditingPage = page;\n        this.removeEdgeComponents([page]);\n        this.renderPagesEdgeComponents([page]);\n    }\n\n    updateEdgeByLocation(updatedPageType: PageType): void {\n        DomHelper.translate(this.element, 0, -this.config.scrollTop);\n        let pagesToRender: number[] = [];\n        for (let edgeElement of this.edgeElements) {\n            if (edgeElement.pageType !== updatedPageType || pagesToRender.includes(edgeElement.page)) {\n                continue;\n            }\n\n            pagesToRender.push(edgeElement.page);\n        }\n        this.removeEdgeComponents(pagesToRender);\n        this.renderPagesEdgeComponents(pagesToRender);\n    }\n\n    updateLines(config: ILayerConfig): void {\n        DomHelper.translate(this.element, 0, -config.scrollTop);\n        this.config = config;\n        while (this.lines.length) {\n            this.lines.pop();\n        }\n\n        this.lines.push(this.renderTextParagraph(config.contentRange));\n    }\n\n    scrollPages(config: ILayerConfig): void {\n        DomHelper.translate(this.element, 0, -config.scrollTop);\n\n        const removedPages = this.config.pages.filter(x => !config.pages.includes(x));\n        this.removeEdgeComponents(removedPages);\n\n        const newPages = config.pages.filter(x => !this.config.pages.includes(x));\n        this.renderPagesEdgeComponents(newPages);\n    }\n\n    scrollLines(config: ILayerConfig): void {\n        const oldConfig = this.config;\n        this.config = config;\n        DomHelper.translate(this.element, 0, -config.scrollTop);\n\n        const oldLastRow = oldConfig ? oldConfig.contentRange.end : -1;\n\n        if (!oldConfig || oldLastRow < config.contentRange.start || config.contentRange.end < oldConfig.contentRange.start) {\n            return this.updateLines(config);\n        }\n\n        if (oldConfig.contentRange.start < config.contentRange.start) {\n            for (let row = config.contentRange.start - oldConfig.contentRange.start; row > 0; row--) {\n                this.lines.shift();\n            }\n        }\n\n        if (oldConfig.contentRange.end > config.contentRange.end) {\n            for (let row = oldConfig.contentRange.end - config.contentRange.end; row > 0; row--) {\n                this.lines.pop();\n            }\n        }\n\n        if (oldConfig.contentRange.start > config.contentRange.start) {\n            const lines = this.renderTextParagraph(\n                new DistanceModel({ start: config.contentRange.start, end: oldConfig.contentRange.start - 1 })\n            );\n            this.lines.unshift(lines);\n        }\n\n        if (oldConfig.contentRange.end < config.contentRange.end) {\n            const lines = this.renderTextParagraph(\n                new DistanceModel({ start: oldConfig.contentRange.end + 1, end: config.contentRange.end })\n            );\n            this.lines.push(lines);\n        }\n    }\n\n    protected getEdgeParagraphTop(topOffset: number, page: number): number {\n        const paragraphTop = this.session.pagesWrap.pagesSpace + topOffset;\n        return paragraphTop + (page - 1) * (this.session.pagesWrap.pageHeight + this.session.pagesWrap.pagesSpace);\n    }\n\n    protected getParagraphTop(row: number): number {\n        return this.session.pagesWrap.getParagraphTop(row);\n    }\n\n    private renderPagesEdgeComponents(pages: number[]): void {\n        const pagesWrap = this.session.pagesWrap;\n        for (let page of pages) {\n            const header = this.session.customComponents.edges.getComponentByPage(page, EdgeType.Header);\n            const headerHeight = this.session.customComponents.edges.getComponentHeight(page, EdgeType.Header);\n            if (header) {\n                this.renderEdgeComponent(header, headerHeight, page);\n            }\n\n            const footer = this.session.customComponents.edges.getComponentByPage(page, EdgeType.Footer);\n            const footerHeight = this.session.customComponents.edges.getComponentHeight(page, EdgeType.Footer);\n            if (footer) {\n                const topOffset = pagesWrap.pageHeight - footerHeight;\n                this.renderEdgeComponent(footer, footerHeight, page, topOffset);\n            }\n        }\n    }\n\n    private renderEdgeComponent(edgeComponent: ComponentRef<NoderEdgeComponent>, edgeHeight: number, page: number, topOffset = 0): void {\n        const container = RenderingHelper.createDivContainer('noder-edge-group');\n        let paragraphTop = this.getEdgeParagraphTop(topOffset, page);\n        DomHelper.setStyle(container.style, 'height', `${edgeHeight}px`);\n        DomHelper.setStyle(container.style, 'top', `${paragraphTop}px`);\n\n        const componentElement = (edgeComponent.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n        if (this.edgeEditingPage === page) {\n            componentElement.setAttribute('data-session-id', `${edgeComponent.instance.sessionId}`);\n            container.appendChild(componentElement);\n            this.element.appendChild(container);\n            this.edgeElements.push(new EdgeElementModel({ page, element: container, pageType: edgeComponent.instance.model.pageType }));\n            return;\n        }\n\n        const componentCopy = componentElement.cloneNode(true) as HTMLElement;\n        componentCopy.setAttribute('data-session-id', `${edgeComponent.instance.sessionId}`);\n        container.appendChild(componentCopy);\n        this.element.appendChild(container);\n        this.edgeElements.push(new EdgeElementModel({ page, element: container, pageType: edgeComponent.instance.model.pageType }));\n        this.editorService.edgeElementCopyUpdated(componentCopy, page);\n    }\n\n    private removeEdgeComponents(removedPages: number[]): void {\n        let removeIndex = this.edgeElements.findIndex(x => removedPages.includes(x.page));\n        while (removeIndex !== -1) {\n            const removedElement = this.edgeElements[removeIndex];\n            DomHelper.removeElement(removedElement.element);\n            this.edgeElements.splice(removeIndex, 1);\n            removeIndex = this.edgeElements.findIndex(x => removedPages.includes(x.page));\n        }\n    }\n\n    private renderTextParagraph(rowsDistance: DistanceModel): Cell[] {\n        const fragment: Cell[] = [];\n        for (let row = rowsDistance.start; row <= rowsDistance.end; row++) {\n            const paragraphCell = this.lines.createCell(row);\n            paragraphCell.element.className = 'noder-line-group';\n            DomHelper.removeChildren(paragraphCell.element);\n            const paragraphHeight = this.session.pagesWrap.getParagraphHeight(row);\n            const paragraphTop = this.getParagraphTop(row);\n            DomHelper.setStyle(paragraphCell.element.style, 'height', `${paragraphHeight}px`);\n            DomHelper.setStyle(paragraphCell.element.style, 'top', `${paragraphTop}px`);\n            DomHelper.setStyle(paragraphCell.element.style, 'padding-left', `${this.session.pagesWrap.documentMargin.left}px`);\n            DomHelper.setStyle(paragraphCell.element.style, 'padding-right', `${this.session.pagesWrap.documentMargin.right}px`);\n            const paragraph = this.session.pagesWrap.paragraphs[row];\n            if (paragraph.numberingData.numberingId !== null) {\n                const numberingElement = this.renderingHelper.renderNumberingMarker(\n                    paragraph,\n                    this.element,\n                    this.session.generalProperties.scalingRatio\n                );\n                numberingElement.className = 'numberingMarker';\n                paragraphCell.element.appendChild(numberingElement);\n            }\n\n            this.renderTextLines(paragraphCell.element, row);\n            fragment.push(paragraphCell);\n        }\n\n        return fragment;\n    }\n\n    private renderTextLines(parent: Node, row: number): void {\n        const linesContainerElement = this.renderingHelper.createDivContainer('lines-container');\n        const currentParagraph = this.session.pagesWrap.paragraphs[row];\n        const paragraphHeight = ParagraphHelper.getParagraphHeight(currentParagraph.textLinesInfo);\n        DomHelper.setStyle(linesContainerElement.style, 'height', `${paragraphHeight}px`);\n        parent.appendChild(linesContainerElement);\n\n        const startIndex = this.session.document.positionToIndex({ row, column: 0 });\n        const endIndex = this.session.document.positionToIndex({ row: row + 1, column: 0 }) - 1;\n        const formats = FormatStyleHelper.getFormatsAtRange(this.session.model.formats, startIndex, endIndex);\n        const splits = this.session.wrapData[row];\n        const formatsExt = formats.map(\n            format =>\n                new FormatExtModel({\n                    ...format,\n                    content: this.session.model.content.substring(format.startIndex, format.endIndex + 1)\n                })\n        );\n        if (splits?.length) {\n            const distance = new DistanceModel({ start: startIndex, end: endIndex });\n            this.renderingHelper.renderContentWrappedLine(\n                { currentElement: this.element, parentNode: linesContainerElement },\n                splits,\n                currentParagraph,\n                formatsExt,\n                distance,\n                this.session.customContentService,\n                this.session.customComponents,\n                this.session.generalProperties.scalingRatio,\n                this.session.model.breaks\n            );\n        } else {\n            const numberingOffsetLeft =\n                currentParagraph.numberingData.numberingId === null\n                    ? 0\n                    : currentParagraph.numberingData.width + currentParagraph.numberingData.paddingLeft;\n            const lastLineEl = this.renderingHelper.createLineElement(\n                currentParagraph.textLinesInfo[0],\n                numberingOffsetLeft,\n                this.session.generalProperties.scalingRatio\n            );\n            linesContainerElement.appendChild(lastLineEl);\n            const rowDistance = new DistanceModel({ start: startIndex, end: endIndex });\n            this.renderingHelper.renderContentSimpleLine(\n                { currentElement: this.element, parentNode: lastLineEl },\n                formatsExt,\n                rowDistance,\n                this.session.customContentService,\n                this.session.customComponents,\n                this.session.model.breaks\n            );\n        }\n    }\n\n    private pagesCountChangedHandler = (event: { pagesCount: number; pageHeight: number }) => {\n        this.lines.setSizes(event.pagesCount, event.pageHeight);\n    };\n}\n"]}
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.layer.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/display/layers/text.layer.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, EmbeddedViewRef } from '@angular/core';\n\nimport { Cell } from '../cell.interface';\nimport { DistanceModel } from '../../execution/distance.model';\nimport { DomHelper } from '../../execution/helpers/dom.helper';\nimport { EdgeElementModel } from '../../components/edges/edge-element.model';\nimport { EdgeType } from '../../components/edges/edge-type.enum';\nimport { EditSession } from '../../execution/edit.session';\nimport { EditorService } from '../../interaction/editor.service';\nimport { FormatExtModel } from '../../content/display-data/format-ext.model';\nimport { FormatStyleHelper } from '../../execution/helpers/format-style.helper';\nimport { ILayerConfig } from './layer.config';\nimport { Lines } from '../../content/display-data/lines';\nimport { NoderEdgeComponent } from '../../components/edges/edge.component';\nimport { PageType } from '../../components/edges/page-type.enum';\nimport { ParagraphHelper } from '../../execution/helpers/paragraph.helper';\nimport { RenderingHelper } from '../rendering.helper';\n\nexport class TextLayer {\n    element: HTMLElement;\n\n    lines: Lines;\n\n    config: ILayerConfig;\n\n    edgeElements: EdgeElementModel[] = [];\n\n    edgeEditingPage: number | null = null;\n\n    constructor(\n        parentElement: HTMLElement,\n        protected session: EditSession,\n        private editorService: EditorService,\n        private renderingHelper = RenderingHelper\n    ) {\n        this.element = document.createElement('div');\n        this.element.className = 'noder-layer noder-text-layer';\n        parentElement.appendChild(this.element);\n\n        this.lines = new Lines(this.element);\n\n        this.session.displayData.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n        this.element.style.width = `${this.session.displayData.pageWidth}px`;\n    }\n\n    destroy(): void {\n        this.session.displayData.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n    }\n\n    updateEdges(config: ILayerConfig): void {\n        DomHelper.translate(this.element, 0, -config.scrollTop);\n        while (this.edgeElements.length) {\n            const removedEl = this.edgeElements.pop();\n            DomHelper.removeElement(removedEl.element);\n        }\n\n        this.renderPagesEdgeComponents(config.pages);\n    }\n\n    edgeEditingPageUpdated(page: number | null): void {\n        this.edgeEditingPage = page;\n        this.removeEdgeComponents([page]);\n        this.renderPagesEdgeComponents([page]);\n    }\n\n    updateEdgeByLocation(updatedPageType: PageType): void {\n        DomHelper.translate(this.element, 0, -this.config.scrollTop);\n        let pagesToRender: number[] = [];\n        for (let edgeElement of this.edgeElements) {\n            if (edgeElement.pageType !== updatedPageType || pagesToRender.includes(edgeElement.page)) {\n                continue;\n            }\n\n            pagesToRender.push(edgeElement.page);\n        }\n        this.removeEdgeComponents(pagesToRender);\n        this.renderPagesEdgeComponents(pagesToRender);\n    }\n\n    updateLines(config: ILayerConfig): void {\n        DomHelper.translate(this.element, 0, -config.scrollTop);\n        this.config = config;\n        while (this.lines.length) {\n            this.lines.pop();\n        }\n\n        this.lines.push(this.renderTextParagraph(config.contentRange));\n    }\n\n    scrollPages(config: ILayerConfig): void {\n        DomHelper.translate(this.element, 0, -config.scrollTop);\n\n        const removedPages = this.config.pages.filter(x => !config.pages.includes(x));\n        this.removeEdgeComponents(removedPages);\n\n        const newPages = config.pages.filter(x => !this.config.pages.includes(x));\n        this.renderPagesEdgeComponents(newPages);\n    }\n\n    scrollLines(config: ILayerConfig): void {\n        const oldConfig = this.config;\n        this.config = config;\n        DomHelper.translate(this.element, 0, -config.scrollTop);\n\n        const oldLastRow = oldConfig ? oldConfig.contentRange.end : -1;\n\n        if (!oldConfig || oldLastRow < config.contentRange.start || config.contentRange.end < oldConfig.contentRange.start) {\n            return this.updateLines(config);\n        }\n\n        if (oldConfig.contentRange.start < config.contentRange.start) {\n            for (let row = config.contentRange.start - oldConfig.contentRange.start; row > 0; row--) {\n                this.lines.shift();\n            }\n        }\n\n        if (oldConfig.contentRange.end > config.contentRange.end) {\n            for (let row = oldConfig.contentRange.end - config.contentRange.end; row > 0; row--) {\n                this.lines.pop();\n            }\n        }\n\n        if (oldConfig.contentRange.start > config.contentRange.start) {\n            const lines = this.renderTextParagraph(\n                new DistanceModel({ start: config.contentRange.start, end: oldConfig.contentRange.start - 1 })\n            );\n            this.lines.unshift(lines);\n        }\n\n        if (oldConfig.contentRange.end < config.contentRange.end) {\n            const lines = this.renderTextParagraph(\n                new DistanceModel({ start: oldConfig.contentRange.end + 1, end: config.contentRange.end })\n            );\n            this.lines.push(lines);\n        }\n    }\n\n    protected getEdgeParagraphTop(topOffset: number, page: number): number {\n        const paragraphTop = this.session.displayData.pagesSpace + topOffset;\n        return paragraphTop + (page - 1) * (this.session.displayData.pageHeight + this.session.displayData.pagesSpace);\n    }\n\n    protected getParagraphTop(row: number): number {\n        return this.session.displayData.getDistanceFromTop(row);\n    }\n\n    private renderPagesEdgeComponents(pages: number[]): void {\n        const displayData = this.session.displayData;\n        for (let page of pages) {\n            const header = this.session.customComponents.edges.getComponentByPage(page, EdgeType.Header);\n            const headerHeight = this.session.customComponents.edges.getComponentHeight(page, EdgeType.Header);\n            if (header) {\n                this.renderEdgeComponent(header, headerHeight, page);\n            }\n\n            const footer = this.session.customComponents.edges.getComponentByPage(page, EdgeType.Footer);\n            const footerHeight = this.session.customComponents.edges.getComponentHeight(page, EdgeType.Footer);\n            if (footer) {\n                const topOffset = displayData.pageHeight - footerHeight;\n                this.renderEdgeComponent(footer, footerHeight, page, topOffset);\n            }\n        }\n    }\n\n    private renderEdgeComponent(edgeComponent: ComponentRef<NoderEdgeComponent>, edgeHeight: number, page: number, topOffset = 0): void {\n        const container = RenderingHelper.createDivContainer('noder-edge-group');\n        let paragraphTop = this.getEdgeParagraphTop(topOffset, page);\n        DomHelper.setStyle(container.style, 'height', `${edgeHeight}px`);\n        DomHelper.setStyle(container.style, 'top', `${paragraphTop}px`);\n\n        const componentElement = (edgeComponent.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n        if (this.edgeEditingPage === page) {\n            componentElement.setAttribute('data-session-id', `${edgeComponent.instance.sessionId}`);\n            container.appendChild(componentElement);\n            this.element.appendChild(container);\n            this.edgeElements.push(new EdgeElementModel({ page, element: container, pageType: edgeComponent.instance.model.pageType }));\n            return;\n        }\n\n        const componentCopy = componentElement.cloneNode(true) as HTMLElement;\n        componentCopy.setAttribute('data-session-id', `${edgeComponent.instance.sessionId}`);\n        container.appendChild(componentCopy);\n        this.element.appendChild(container);\n        this.edgeElements.push(new EdgeElementModel({ page, element: container, pageType: edgeComponent.instance.model.pageType }));\n        this.editorService.edgeElementCopyUpdated(componentCopy, page);\n    }\n\n    private removeEdgeComponents(removedPages: number[]): void {\n        let removeIndex = this.edgeElements.findIndex(x => removedPages.includes(x.page));\n        while (removeIndex !== -1) {\n            const removedElement = this.edgeElements[removeIndex];\n            DomHelper.removeElement(removedElement.element);\n            this.edgeElements.splice(removeIndex, 1);\n            removeIndex = this.edgeElements.findIndex(x => removedPages.includes(x.page));\n        }\n    }\n\n    private renderTextParagraph(rowsDistance: DistanceModel): Cell[] {\n        const fragment: Cell[] = [];\n        for (let row = rowsDistance.start; row <= rowsDistance.end; row++) {\n            const paragraphCell = this.lines.createCell(row);\n            paragraphCell.element.className = 'noder-line-group';\n            DomHelper.removeChildren(paragraphCell.element);\n            const paragraphHeight = this.session.displayData.getParagraphHeight(row);\n            const paragraphTop = this.getParagraphTop(row);\n            DomHelper.setStyle(paragraphCell.element.style, 'height', `${paragraphHeight}px`);\n            DomHelper.setStyle(paragraphCell.element.style, 'top', `${paragraphTop}px`);\n            DomHelper.setStyle(paragraphCell.element.style, 'padding-left', `${this.session.displayData.pageMargin.left}px`);\n            DomHelper.setStyle(paragraphCell.element.style, 'padding-right', `${this.session.displayData.pageMargin.right}px`);\n            const paragraphSettings = this.session.displayData.getParagraphSettings(row);\n            if (paragraphSettings?.numberingData.numberingId !== null) {\n                const numberingElement = this.renderingHelper.renderNumberingMarker(\n                    paragraphSettings,\n                    this.element,\n                    this.session.generalProperties.scalingRatio\n                );\n                numberingElement.className = 'numberingMarker';\n                paragraphCell.element.appendChild(numberingElement);\n            }\n\n            this.renderTextLines(paragraphCell.element, row);\n            fragment.push(paragraphCell);\n        }\n\n        return fragment;\n    }\n\n    private renderTextLines(parent: Node, row: number): void {\n        const linesContainerElement = this.renderingHelper.createDivContainer('lines-container');\n        const paragraphSettings = this.session.displayData.getParagraphSettings(row);\n        const paragraphHeight = ParagraphHelper.getParagraphHeight(paragraphSettings.textLinesInfo);\n        DomHelper.setStyle(linesContainerElement.style, 'height', `${paragraphHeight}px`);\n        parent.appendChild(linesContainerElement);\n\n        const startIndex = this.session.displayData.positionToIndex({ row, column: 0 });\n        const endIndex = this.session.displayData.positionToIndex({ row: row + 1, column: 0 }) - 1;\n        const formats = FormatStyleHelper.getFormatsAtRange(this.session.model.formats, startIndex, endIndex);\n        const splits = this.session.displayData.paragraphs[row].nextLineIndexes;\n        const formatsExt = formats.map(\n            format =>\n                new FormatExtModel({\n                    ...format,\n                    content: this.session.model.content.substring(format.startIndex, format.endIndex + 1)\n                })\n        );\n        if (splits?.length) {\n            const distance = new DistanceModel({ start: startIndex, end: endIndex });\n            this.renderingHelper.renderContentWrappedLine(\n                { currentElement: this.element, parentNode: linesContainerElement },\n                splits,\n                paragraphSettings,\n                formatsExt,\n                distance,\n                this.session.customContentService,\n                this.session.customComponents,\n                this.session.generalProperties.scalingRatio,\n                this.session.model.breaks\n            );\n        } else {\n            const numberingOffsetLeft =\n                paragraphSettings.numberingData.numberingId === null\n                    ? 0\n                    : paragraphSettings.numberingData.width + paragraphSettings.numberingData.paddingLeft;\n            const lastLineEl = this.renderingHelper.createLineElement(\n                paragraphSettings.textLinesInfo[0],\n                numberingOffsetLeft,\n                this.session.generalProperties.scalingRatio\n            );\n            linesContainerElement.appendChild(lastLineEl);\n            const rowDistance = new DistanceModel({ start: startIndex, end: endIndex });\n            this.renderingHelper.renderContentSimpleLine(\n                { currentElement: this.element, parentNode: lastLineEl },\n                formatsExt,\n                rowDistance,\n                this.session.customContentService,\n                this.session.customComponents,\n                this.session.model.breaks\n            );\n        }\n    }\n\n    private pagesCountChangedHandler = (event: { pagesCount: number; pageHeight: number }) => {\n        this.lines.setSizes(event.pagesCount, event.pageHeight);\n    };\n}\n"]}
@@ -5,7 +5,7 @@ import { PrintTextLayer } from '../layers/print.text.layer';
5
5
  export class PrintRenderer {
6
6
  constructor(mainSession, editorService) {
7
7
  this.mainSession = mainSession;
8
- this.pagesCount = Math.round((mainSession.pagesWrap.pagesSpace * 2 + mainSession.pagesWrap.allPagesHeight) / mainSession.pagesWrap.minHeight);
8
+ this.pagesCount = Math.round((mainSession.displayData.pagesSpace * 2 + mainSession.displayData.allPagesHeight) / mainSession.displayData.minHeight);
9
9
  this.createContent();
10
10
  this.createLayers(editorService);
11
11
  }
@@ -18,13 +18,13 @@ export class PrintRenderer {
18
18
  }
19
19
  computeLayerConfig() {
20
20
  const pages = Array.from(Array(this.pagesCount).keys()).map(x => x + 1);
21
- const pagesWrap = this.mainSession.pagesWrap;
22
- const maxHeight = pagesWrap.pageHeight * this.pagesCount;
23
- const minHeight = pagesWrap.pageHeight;
21
+ const displayData = this.mainSession.displayData;
22
+ const maxHeight = displayData.pageHeight * this.pagesCount;
23
+ const minHeight = displayData.pageHeight;
24
24
  return {
25
- width: this.textLayer.element.clientWidth + pagesWrap.documentMargin.left + pagesWrap.documentMargin.right,
26
- height: pagesWrap.defaultVerticalData.contentHeight,
27
- contentRange: new DistanceModel({ start: 0, end: this.mainSession.pagesWrap.paragraphs.length - 1 }),
25
+ width: this.textLayer.element.clientWidth + displayData.pageMargin.left + displayData.pageMargin.right,
26
+ height: displayData.defaultVerticalData.contentHeight,
27
+ contentRange: new DistanceModel({ start: 0, end: displayData.paragraphs.length - 1 }),
28
28
  minHeight,
29
29
  maxHeight,
30
30
  offset: 0,
@@ -64,4 +64,4 @@ export class PrintRenderer {
64
64
  return `<style>${pageStyle} ${contentStyle}</style>`;
65
65
  }
66
66
  }
67
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"print.renderer.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/display/print/print.renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { DistanceModel } from '../../execution/distance.model';\nimport { EditorService } from '../../interaction/editor.service';\nimport { EditSession } from '../../execution/edit.session';\nimport { ILayerConfig } from '../layers/layer.config';\nimport { PagesLayer } from '../layers/pages.layer';\nimport { PagesWrap } from '../../content/display-data/pages.wrap';\nimport { PrintPagesLayer } from '../layers/print.pages.layer';\nimport { PrintRenderingHelper } from './print.rendering.helper';\nimport { PrintTextLayer } from '../layers/print.text.layer';\n\nexport class PrintRenderer {\n    content: HTMLElement;\n\n    textLayer: PrintTextLayer;\n\n    pagesLayer: PagesLayer;\n\n    originalPagesWrap: PagesWrap;\n\n    documentHtml: string;\n\n    headHtml: string;\n\n    pagesCount: number;\n\n    constructor(private mainSession: EditSession, editorService: EditorService) {\n        this.pagesCount = Math.round(\n            (mainSession.pagesWrap.pagesSpace * 2 + mainSession.pagesWrap.allPagesHeight) / mainSession.pagesWrap.minHeight\n        );\n        this.createContent();\n        this.createLayers(editorService);\n    }\n\n    renderPrintDocument(): void {\n        const layerConfig = this.computeLayerConfig();\n\n        this.pagesLayer.update(layerConfig);\n        this.textLayer.updateLines(layerConfig);\n        this.textLayer.updateEdges(layerConfig);\n\n        this.createDocumentHtml(layerConfig);\n    }\n\n    private computeLayerConfig(): ILayerConfig {\n        const pages = Array.from(Array(this.pagesCount).keys()).map(x => x + 1);\n        const pagesWrap = this.mainSession.pagesWrap;\n        const maxHeight = pagesWrap.pageHeight * this.pagesCount;\n        const minHeight = pagesWrap.pageHeight;\n\n        return {\n            width: this.textLayer.element.clientWidth + pagesWrap.documentMargin.left + pagesWrap.documentMargin.right,\n            height: pagesWrap.defaultVerticalData.contentHeight,\n            contentRange: new DistanceModel({ start: 0, end: this.mainSession.pagesWrap.paragraphs.length - 1 }),\n            minHeight,\n            maxHeight,\n            offset: 0,\n            pages,\n            scrollTop: 0\n        };\n    }\n\n    private createContent(): void {\n        this.content = document.createElement('div');\n        this.content.className = 'noder-content print';\n    }\n\n    private createLayers(editorService: EditorService): void {\n        this.textLayer = new PrintTextLayer(this.content, this.mainSession, editorService, PrintRenderingHelper);\n        this.pagesLayer = new PrintPagesLayer(this.content, this.mainSession);\n    }\n\n    private createDocumentHtml(layerConfig: ILayerConfig): void {\n        const head = this.createHeadWithStyles();\n        let body = `<div class=\"noder-scroller print\" style=\"width: 100%;\">${this.content.innerHTML}</div>`;\n        body = `<div class=\"edit-container noder-editor print\">${body}</div>`;\n        body = `<div class=\"container print\" style=\"height: ${layerConfig.maxHeight}px;\">${body}</div>`;\n        body = `<div class=\"mat-drawer-content print\">${body}</div>`;\n        body = `<div class=\"mat-drawer-container sidenav-container print\">${body}</div>`;\n        body = `<div class=\"base-editor print\">${body}</div>`;\n\n        this.documentHtml = `<!DOCTYPE html><html>${head}${body}</html>`;\n    }\n\n    private createHeadWithStyles(): string {\n        let styles = '';\n        for (let i = 0; i < document.styleSheets.length; i++) {\n            const cssRules = Array.from(document.styleSheets[i].cssRules);\n            cssRules.forEach(rule => (styles += `<style>${rule.cssText}</style>`));\n        }\n\n        return `<head><title>Print</title>${styles}${this.getPrintPageStyle()}</head>`;\n    }\n\n    private getPrintPageStyle(): string {\n        const pageStyle = '@page { margin: 0; }';\n        const contentStyle = `@media print { html, body { width: 100%; height: 100%; } }`;\n        return `<style>${pageStyle} ${contentStyle}</style>`;\n    }\n}\n"]}
67
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"print.renderer.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/display/print/print.renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { DistanceModel } from '../../execution/distance.model';\nimport { EditorService } from '../../interaction/editor.service';\nimport { EditSession } from '../../execution/edit.session';\nimport { ILayerConfig } from '../layers/layer.config';\nimport { PagesLayer } from '../layers/pages.layer';\nimport { PrintPagesLayer } from '../layers/print.pages.layer';\nimport { PrintRenderingHelper } from './print.rendering.helper';\nimport { PrintTextLayer } from '../layers/print.text.layer';\n\nexport class PrintRenderer {\n    content: HTMLElement;\n\n    textLayer: PrintTextLayer;\n\n    pagesLayer: PagesLayer;\n\n    documentHtml: string;\n\n    headHtml: string;\n\n    pagesCount: number;\n\n    constructor(private mainSession: EditSession, editorService: EditorService) {\n        this.pagesCount = Math.round(\n            (mainSession.displayData.pagesSpace * 2 + mainSession.displayData.allPagesHeight) / mainSession.displayData.minHeight\n        );\n        this.createContent();\n        this.createLayers(editorService);\n    }\n\n    renderPrintDocument(): void {\n        const layerConfig = this.computeLayerConfig();\n\n        this.pagesLayer.update(layerConfig);\n        this.textLayer.updateLines(layerConfig);\n        this.textLayer.updateEdges(layerConfig);\n\n        this.createDocumentHtml(layerConfig);\n    }\n\n    private computeLayerConfig(): ILayerConfig {\n        const pages = Array.from(Array(this.pagesCount).keys()).map(x => x + 1);\n        const displayData = this.mainSession.displayData;\n        const maxHeight = displayData.pageHeight * this.pagesCount;\n        const minHeight = displayData.pageHeight;\n\n        return {\n            width: this.textLayer.element.clientWidth + displayData.pageMargin.left + displayData.pageMargin.right,\n            height: displayData.defaultVerticalData.contentHeight,\n            contentRange: new DistanceModel({ start: 0, end: displayData.paragraphs.length - 1 }),\n            minHeight,\n            maxHeight,\n            offset: 0,\n            pages,\n            scrollTop: 0\n        };\n    }\n\n    private createContent(): void {\n        this.content = document.createElement('div');\n        this.content.className = 'noder-content print';\n    }\n\n    private createLayers(editorService: EditorService): void {\n        this.textLayer = new PrintTextLayer(this.content, this.mainSession, editorService, PrintRenderingHelper);\n        this.pagesLayer = new PrintPagesLayer(this.content, this.mainSession);\n    }\n\n    private createDocumentHtml(layerConfig: ILayerConfig): void {\n        const head = this.createHeadWithStyles();\n        let body = `<div class=\"noder-scroller print\" style=\"width: 100%;\">${this.content.innerHTML}</div>`;\n        body = `<div class=\"edit-container noder-editor print\">${body}</div>`;\n        body = `<div class=\"container print\" style=\"height: ${layerConfig.maxHeight}px;\">${body}</div>`;\n        body = `<div class=\"mat-drawer-content print\">${body}</div>`;\n        body = `<div class=\"mat-drawer-container sidenav-container print\">${body}</div>`;\n        body = `<div class=\"base-editor print\">${body}</div>`;\n\n        this.documentHtml = `<!DOCTYPE html><html>${head}${body}</html>`;\n    }\n\n    private createHeadWithStyles(): string {\n        let styles = '';\n        for (let i = 0; i < document.styleSheets.length; i++) {\n            const cssRules = Array.from(document.styleSheets[i].cssRules);\n            cssRules.forEach(rule => (styles += `<style>${rule.cssText}</style>`));\n        }\n\n        return `<head><title>Print</title>${styles}${this.getPrintPageStyle()}</head>`;\n    }\n\n    private getPrintPageStyle(): string {\n        const pageStyle = '@page { margin: 0; }';\n        const contentStyle = `@media print { html, body { width: 100%; height: 100%; } }`;\n        return `<style>${pageStyle} ${contentStyle}</style>`;\n    }\n}\n"]}
@@ -47,8 +47,7 @@ export class Renderer extends EventEmitting {
47
47
  this.selectionLayer = new SelectionLayer(this.content, 'text-selection', this.session);
48
48
  this.cursorLayer = new CursorLayer(this.content, this.session);
49
49
  this.loop = new RenderLoop(changes => this.renderChanges(changes));
50
- this.loop.schedule({ text: true });
51
- this.session.pagesWrap.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);
50
+ this.session.displayData.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);
52
51
  }
53
52
  renderChanges(changes, force) {
54
53
  changes.apply(this.changes);
@@ -154,7 +153,7 @@ export class Renderer extends EventEmitting {
154
153
  this.editorService.rendererUpdated(this.session.sessionId);
155
154
  }
156
155
  destroy() {
157
- this.session.pagesWrap.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);
156
+ this.session.displayData.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);
158
157
  this.textLayer.destroy();
159
158
  DomHelper.removeChildren(this.container);
160
159
  }
@@ -177,14 +176,15 @@ export class Renderer extends EventEmitting {
177
176
  this.cursorLayer.detectVisibility();
178
177
  }
179
178
  computeLayerConfig() {
180
- const pagesWrap = this.session.pagesWrap;
181
- const maxHeight = pagesWrap.allPagesHeight;
182
- const minHeight = pagesWrap.minHeight;
179
+ const displayData = this.session.displayData;
180
+ const maxHeight = displayData.allPagesHeight;
181
+ const minHeight = displayData.minHeight;
183
182
  const changes = new RenderChangesModel({ scroll: true });
183
+ // todo check logic after move wrapdata to display data
184
184
  this.layerConfig = {
185
- width: this.session.pagesWrap.contentWidth + pagesWrap.documentMargin.left + pagesWrap.documentMargin.right,
186
- height: pagesWrap.defaultVerticalData.contentHeight,
187
- contentRange: new DistanceModel({ start: 0, end: pagesWrap.paragraphs.length - 1 }),
185
+ width: this.session.displayData.contentWidth + displayData.pageMargin.left + displayData.pageMargin.right,
186
+ height: displayData.defaultVerticalData.contentHeight,
187
+ contentRange: new DistanceModel({ start: 0, end: displayData.paragraphs.filter(x => x.paragraphSettings).length - 1 }),
188
188
  minHeight,
189
189
  maxHeight,
190
190
  offset: 0,
@@ -203,4 +203,4 @@ export class Renderer extends EventEmitting {
203
203
  }
204
204
  }
205
205
  }
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../../../../projects/ngx-noder/src/lib/editor/display/renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { CursorLayer } from './layers/cursor.layer';\nimport { CursorParagraph } from '../positioning/cursor-paragraph';\nimport { DistanceModel } from '../execution/distance.model';\nimport { DomHelper } from '../execution/helpers/dom.helper';\nimport { EditorService } from '../interaction/editor.service';\nimport { EditSession } from '../execution/edit.session';\nimport { EventEmitting } from '../core/event-emitting';\nimport { ILayerConfig } from './layers/layer.config';\nimport { PositionHelper } from '../positioning/position.helper';\nimport { Range } from '../positioning/range';\nimport { RenderChangesModel } from './render-changes.model';\nimport { RenderLoop } from './renderloop';\nimport { SelectionLayer } from './layers/selection.layer';\nimport { TextLayer } from './layers/text.layer';\n\nexport class Renderer extends EventEmitting {\n    isMousePressed: boolean;\n\n    container: HTMLElement;\n\n    content: HTMLElement;\n\n    cursorLayer: CursorLayer;\n\n    textLayer: TextLayer;\n\n    selectionLayer: SelectionLayer;\n\n    loop: RenderLoop;\n\n    textarea: HTMLElement;\n\n    layerConfig: ILayerConfig = {\n        width: 1,\n        contentRange: new DistanceModel({ start: 0, end: 0 }),\n        minHeight: 1,\n        maxHeight: 1,\n        offset: 0,\n        height: 1,\n        scrollTop: 0,\n        pages: [],\n        visibleRange: {\n            startParagraph: 0,\n            startLine: 0,\n            startScreenLine: 0,\n            startScreenFullLine: 0,\n            endParagraph: 0,\n            endLine: 0,\n            endScreenLine: 0,\n            endScreenFullLine: 0\n        }\n    };\n\n    changes = new RenderChangesModel();\n\n    readonly textareaSize = {\n        height: 1,\n        width: 1\n    };\n\n    constructor(parentContainer: HTMLElement, private editorService: EditorService, public session: EditSession) {\n        super();\n        this.container = parentContainer;\n        this.container.className += ' noder-editor';\n        this.createContentContainer();\n        this.textLayer = new TextLayer(this.content, this.session, this.editorService);\n        this.selectionLayer = new SelectionLayer(this.content, 'text-selection', this.session);\n        this.cursorLayer = new CursorLayer(this.content, this.session);\n        this.loop = new RenderLoop(changes => this.renderChanges(changes));\n        this.loop.schedule({ text: true });\n        this.session.pagesWrap.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n    }\n\n    renderChanges(changes: RenderChangesModel, force?: boolean): void {\n        changes.apply(this.changes);\n        this.changes = new RenderChangesModel();\n\n        if (!changes.any && !force) {\n            this.changes.apply(changes);\n\n            return;\n        }\n\n        // text, scrolling and resize changes can cause the view port size to change\n        if (changes.full || changes.size || changes.text || changes.lines || changes.scroll) {\n            changes.apply(this.computeLayerConfig());\n\n            DomHelper.translate(this.content, 0, -this.layerConfig.offset);\n\n            DomHelper.setStyle(this.content.style, 'width', `${this.layerConfig.width}px`);\n            DomHelper.setStyle(this.content.style, 'height', `${this.layerConfig.height}px`);\n        }\n\n        // full\n        if (changes.full) {\n            this.renderFull();\n            this.editorService.rendererUpdated(this.session.sessionId);\n\n            return;\n        }\n\n        if (changes.text || changes.scroll) {\n            this.renderText();\n        }\n\n        if (changes.cursor) {\n            this.renderCursor();\n        }\n\n        if (changes.marker || changes.selection) {\n            this.renderSelection();\n        }\n\n        this.editorService.rendererUpdated(this.session.sessionId);\n    }\n\n    /**\n     * Triggers a partial update of the text, from the range given by the two parameters.\n     **/\n    updateLines(firstRow: number, lastRow: number): void {\n        // If the change happened offscreen above us then it's possible\n        // that a new line wrap will affect the position of the lines on our\n        // screen, so they need redrawn.\n        if (lastRow < this.layerConfig.contentRange.start || firstRow > this.layerConfig.contentRange.end) {\n            return;\n        }\n\n        this.loop.schedule({ lines: true });\n    }\n\n    moveTextAreaToCursor(): void {\n        if (this.isMousePressed || !this.textarea) {\n            return;\n        }\n\n        let cursorPosition = this.cursorLayer.cursorPosition;\n        if (!cursorPosition) {\n            return;\n        }\n\n        const posTop = cursorPosition.pageY - this.layerConfig.offset;\n        if (posTop < 0 || posTop > this.layerConfig.height - this.textareaSize.height) {\n            DomHelper.translate(this.textarea, 0, 0);\n            return;\n        }\n\n        DomHelper.setStyle(this.textarea.style, 'height', `${this.textareaSize.height}px`);\n        DomHelper.setStyle(this.textarea.style, 'width', `${this.textareaSize.width}px`);\n        DomHelper.translate(\n            this.textarea,\n            Math.min(cursorPosition.pageX, this.textareaSize.width),\n            Math.min(posTop, this.textareaSize.height)\n        );\n    }\n\n    updateSelection(range: Range): void {\n        if (range.isEmpty && this.selectionLayer.marker) {\n            this.selectionLayer.marker = null;\n            this.loop.schedule({ selection: true });\n        } else if (!range.isEmpty && !this.selectionLayer.marker?.isEqual(range)) {\n            this.selectionLayer.marker = range;\n            this.loop.schedule({ selection: true });\n        }\n    }\n\n    /**\n     * Triggers a full update of the text, for all the rows.\n     **/\n    updateText(): void {\n        this.loop.schedule({ text: true });\n    }\n\n    /**\n     * Triggers a full update of all the layers, for all the rows.\n     **/\n    updateFull(force?: boolean): void {\n        if (force) {\n            this.renderChanges(new RenderChangesModel({ full: true }), true);\n\n            return;\n        }\n\n        this.loop.schedule({ full: true });\n    }\n\n    updateCursor(): void {\n        this.loop.schedule({ cursor: true });\n    }\n\n    screenToTextCoordinates(x: number, y: number): CursorParagraph {\n        const screen = PositionHelper.pixelToScreen(this.session, x, y, this.container.getBoundingClientRect());\n\n        return PositionHelper.screenToDocument(this.session, screen.row, screen.column);\n    }\n\n    showCursor(): void {\n        this.cursorLayer.showCursor();\n        DomHelper.addCssClass(this.container, 'ace_focus');\n        this.editorService.rendererUpdated(this.session.sessionId);\n    }\n\n    hideCursor(): void {\n        this.cursorLayer.hideCursor();\n        DomHelper.removeCssClass(this.container, 'ace_focus');\n        this.editorService.rendererUpdated(this.session.sessionId);\n    }\n\n    destroy(): void {\n        this.session.pagesWrap.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n        this.textLayer.destroy();\n        DomHelper.removeChildren(this.container);\n    }\n\n    renderFull(): void {\n        this.textLayer.updateLines(this.layerConfig);\n        this.selectionLayer.update(this.layerConfig);\n        this.cursorLayer.update(this.layerConfig);\n        this.moveTextAreaToCursor();\n    }\n\n    renderText(): void {\n        this.textLayer.updateLines(this.layerConfig);\n        this.cursorLayer.detectVisibility();\n    }\n\n    renderCursor(): void {\n        this.cursorLayer.update(this.layerConfig);\n        this.moveTextAreaToCursor();\n    }\n\n    renderSelection(): void {\n        this.selectionLayer.update(this.layerConfig);\n        this.cursorLayer.detectVisibility();\n    }\n\n    private computeLayerConfig(): RenderChangesModel {\n        const pagesWrap = this.session.pagesWrap;\n        const maxHeight = pagesWrap.allPagesHeight;\n        const minHeight = pagesWrap.minHeight;\n\n        const changes = new RenderChangesModel({ scroll: true });\n        this.layerConfig = {\n            width: this.session.pagesWrap.contentWidth + pagesWrap.documentMargin.left + pagesWrap.documentMargin.right,\n            height: pagesWrap.defaultVerticalData.contentHeight,\n            contentRange: new DistanceModel({ start: 0, end: pagesWrap.paragraphs.length - 1 }),\n            minHeight,\n            maxHeight,\n            offset: 0,\n            scrollTop: this.session.scrollTop\n        };\n\n        return changes;\n    }\n\n    private pagesCountChangedHandler = (): void => {\n        this.loop.schedule({ lines: true, selection: true });\n    };\n\n    private createContentContainer(): void {\n        this.content = document.createElement('div');\n        this.content.className = 'noder-content';\n\n        if (this.container.firstChild) {\n            this.container.firstChild.appendChild(this.content);\n        } else {\n            this.container.appendChild(this.content);\n        }\n    }\n}\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../../../../projects/ngx-noder/src/lib/editor/display/renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { CursorLayer } from './layers/cursor.layer';\nimport { CursorParagraph } from '../positioning/cursor-paragraph';\nimport { DistanceModel } from '../execution/distance.model';\nimport { DomHelper } from '../execution/helpers/dom.helper';\nimport { EditorService } from '../interaction/editor.service';\nimport { EditSession } from '../execution/edit.session';\nimport { EventEmitting } from '../core/event-emitting';\nimport { ILayerConfig } from './layers/layer.config';\nimport { PositionHelper } from '../positioning/position.helper';\nimport { Range } from '../positioning/range';\nimport { RenderChangesModel } from './render-changes.model';\nimport { RenderLoop } from './renderloop';\nimport { SelectionLayer } from './layers/selection.layer';\nimport { TextLayer } from './layers/text.layer';\n\nexport class Renderer extends EventEmitting {\n    isMousePressed: boolean;\n\n    container: HTMLElement;\n\n    content: HTMLElement;\n\n    cursorLayer: CursorLayer;\n\n    textLayer: TextLayer;\n\n    selectionLayer: SelectionLayer;\n\n    loop: RenderLoop;\n\n    textarea: HTMLElement;\n\n    layerConfig: ILayerConfig = {\n        width: 1,\n        contentRange: new DistanceModel({ start: 0, end: 0 }),\n        minHeight: 1,\n        maxHeight: 1,\n        offset: 0,\n        height: 1,\n        scrollTop: 0,\n        pages: [],\n        visibleRange: {\n            startParagraph: 0,\n            startLine: 0,\n            startScreenLine: 0,\n            startScreenFullLine: 0,\n            endParagraph: 0,\n            endLine: 0,\n            endScreenLine: 0,\n            endScreenFullLine: 0\n        }\n    };\n\n    changes = new RenderChangesModel();\n\n    readonly textareaSize = {\n        height: 1,\n        width: 1\n    };\n\n    constructor(parentContainer: HTMLElement, private editorService: EditorService, public session: EditSession) {\n        super();\n        this.container = parentContainer;\n        this.container.className += ' noder-editor';\n        this.createContentContainer();\n        this.textLayer = new TextLayer(this.content, this.session, this.editorService);\n        this.selectionLayer = new SelectionLayer(this.content, 'text-selection', this.session);\n        this.cursorLayer = new CursorLayer(this.content, this.session);\n        this.loop = new RenderLoop(changes => this.renderChanges(changes));\n        this.session.displayData.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n    }\n\n    renderChanges(changes: RenderChangesModel, force?: boolean): void {\n        changes.apply(this.changes);\n        this.changes = new RenderChangesModel();\n\n        if (!changes.any && !force) {\n            this.changes.apply(changes);\n\n            return;\n        }\n\n        // text, scrolling and resize changes can cause the view port size to change\n        if (changes.full || changes.size || changes.text || changes.lines || changes.scroll) {\n            changes.apply(this.computeLayerConfig());\n\n            DomHelper.translate(this.content, 0, -this.layerConfig.offset);\n\n            DomHelper.setStyle(this.content.style, 'width', `${this.layerConfig.width}px`);\n            DomHelper.setStyle(this.content.style, 'height', `${this.layerConfig.height}px`);\n        }\n\n        // full\n        if (changes.full) {\n            this.renderFull();\n            this.editorService.rendererUpdated(this.session.sessionId);\n\n            return;\n        }\n\n        if (changes.text || changes.scroll) {\n            this.renderText();\n        }\n\n        if (changes.cursor) {\n            this.renderCursor();\n        }\n\n        if (changes.marker || changes.selection) {\n            this.renderSelection();\n        }\n\n        this.editorService.rendererUpdated(this.session.sessionId);\n    }\n\n    /**\n     * Triggers a partial update of the text, from the range given by the two parameters.\n     **/\n    updateLines(firstRow: number, lastRow: number): void {\n        // If the change happened offscreen above us then it's possible\n        // that a new line wrap will affect the position of the lines on our\n        // screen, so they need redrawn.\n        if (lastRow < this.layerConfig.contentRange.start || firstRow > this.layerConfig.contentRange.end) {\n            return;\n        }\n\n        this.loop.schedule({ lines: true });\n    }\n\n    moveTextAreaToCursor(): void {\n        if (this.isMousePressed || !this.textarea) {\n            return;\n        }\n\n        let cursorPosition = this.cursorLayer.cursorPosition;\n        if (!cursorPosition) {\n            return;\n        }\n\n        const posTop = cursorPosition.pageY - this.layerConfig.offset;\n        if (posTop < 0 || posTop > this.layerConfig.height - this.textareaSize.height) {\n            DomHelper.translate(this.textarea, 0, 0);\n            return;\n        }\n\n        DomHelper.setStyle(this.textarea.style, 'height', `${this.textareaSize.height}px`);\n        DomHelper.setStyle(this.textarea.style, 'width', `${this.textareaSize.width}px`);\n        DomHelper.translate(\n            this.textarea,\n            Math.min(cursorPosition.pageX, this.textareaSize.width),\n            Math.min(posTop, this.textareaSize.height)\n        );\n    }\n\n    updateSelection(range: Range): void {\n        if (range.isEmpty && this.selectionLayer.marker) {\n            this.selectionLayer.marker = null;\n            this.loop.schedule({ selection: true });\n        } else if (!range.isEmpty && !this.selectionLayer.marker?.isEqual(range)) {\n            this.selectionLayer.marker = range;\n            this.loop.schedule({ selection: true });\n        }\n    }\n\n    /**\n     * Triggers a full update of the text, for all the rows.\n     **/\n    updateText(): void {\n        this.loop.schedule({ text: true });\n    }\n\n    /**\n     * Triggers a full update of all the layers, for all the rows.\n     **/\n    updateFull(force?: boolean): void {\n        if (force) {\n            this.renderChanges(new RenderChangesModel({ full: true }), true);\n\n            return;\n        }\n\n        this.loop.schedule({ full: true });\n    }\n\n    updateCursor(): void {\n        this.loop.schedule({ cursor: true });\n    }\n\n    screenToTextCoordinates(x: number, y: number): CursorParagraph {\n        const screen = PositionHelper.pixelToScreen(this.session, x, y, this.container.getBoundingClientRect());\n\n        return PositionHelper.screenToDocument(this.session, screen.row, screen.column);\n    }\n\n    showCursor(): void {\n        this.cursorLayer.showCursor();\n        DomHelper.addCssClass(this.container, 'ace_focus');\n        this.editorService.rendererUpdated(this.session.sessionId);\n    }\n\n    hideCursor(): void {\n        this.cursorLayer.hideCursor();\n        DomHelper.removeCssClass(this.container, 'ace_focus');\n        this.editorService.rendererUpdated(this.session.sessionId);\n    }\n\n    destroy(): void {\n        this.session.displayData.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n        this.textLayer.destroy();\n        DomHelper.removeChildren(this.container);\n    }\n\n    renderFull(): void {\n        this.textLayer.updateLines(this.layerConfig);\n        this.selectionLayer.update(this.layerConfig);\n        this.cursorLayer.update(this.layerConfig);\n        this.moveTextAreaToCursor();\n    }\n\n    renderText(): void {\n        this.textLayer.updateLines(this.layerConfig);\n        this.cursorLayer.detectVisibility();\n    }\n\n    renderCursor(): void {\n        this.cursorLayer.update(this.layerConfig);\n        this.moveTextAreaToCursor();\n    }\n\n    renderSelection(): void {\n        this.selectionLayer.update(this.layerConfig);\n        this.cursorLayer.detectVisibility();\n    }\n\n    private computeLayerConfig(): RenderChangesModel {\n        const displayData = this.session.displayData;\n        const maxHeight = displayData.allPagesHeight;\n        const minHeight = displayData.minHeight;\n\n        const changes = new RenderChangesModel({ scroll: true });\n        // todo check logic after move wrapdata to display data\n        this.layerConfig = {\n            width: this.session.displayData.contentWidth + displayData.pageMargin.left + displayData.pageMargin.right,\n            height: displayData.defaultVerticalData.contentHeight,\n            contentRange: new DistanceModel({ start: 0, end: displayData.paragraphs.filter(x => x.paragraphSettings).length - 1 }),\n            minHeight,\n            maxHeight,\n            offset: 0,\n            scrollTop: this.session.scrollTop\n        };\n\n        return changes;\n    }\n\n    private pagesCountChangedHandler = (): void => {\n        this.loop.schedule({ lines: true, selection: true });\n    };\n\n    private createContentContainer(): void {\n        this.content = document.createElement('div');\n        this.content.className = 'noder-content';\n\n        if (this.container.firstChild) {\n            this.container.firstChild.appendChild(this.content);\n        } else {\n            this.container.appendChild(this.content);\n        }\n    }\n}\n"]}