@talrace/ngx-noder 0.0.8 → 0.0.10

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 (102) hide show
  1. package/esm2022/lib/apart-components/add-link-dialog/add-link-dialog.component.mjs +21 -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/editor-mobile-toolbar/editor-mobile-toolbar.component.mjs +2 -2
  6. package/esm2022/lib/apart-components/editor-toolbar/shared/toolbar-styles.helper.mjs +1 -8
  7. package/esm2022/lib/editor/components/edges/edge.component.mjs +2 -2
  8. package/esm2022/lib/editor/components/edges/edges.mjs +21 -2
  9. package/esm2022/lib/editor/components/image/input-handler/image-input.handler.mjs +18 -1
  10. package/esm2022/lib/editor/components/shared/services/custom-content.service.mjs +22 -56
  11. package/esm2022/lib/editor/components/table/components/table-cell.component.mjs +6 -6
  12. package/esm2022/lib/editor/components/table/components/table.component.mjs +13 -4
  13. package/esm2022/lib/editor/components/table/models/cell-data.model.mjs +3 -4
  14. package/esm2022/lib/editor/components/table/selection/table-selection.mjs +15 -5
  15. package/esm2022/lib/editor/content/constants/editor.const.mjs +9 -1
  16. package/esm2022/lib/editor/content/display-data/display-data.mjs +839 -0
  17. package/esm2022/lib/editor/content/display-data/general-properties.model.mjs +1 -1
  18. package/esm2022/lib/editor/content/display-data/models/paragraph-info.model.mjs +8 -0
  19. package/esm2022/lib/editor/content/display-data/paragraph.mjs +5 -1
  20. package/esm2022/lib/editor/content/display-data/text-line-info.mjs +2 -1
  21. package/esm2022/lib/editor/content/display-data/toolbar-styles.interface.mjs +1 -1
  22. package/esm2022/lib/editor/content/helpers/content-style.helper.mjs +12 -30
  23. package/esm2022/lib/editor/content/helpers/display-token.helper.mjs +62 -0
  24. package/esm2022/lib/editor/content/helpers/link.helper.mjs +6 -0
  25. package/esm2022/lib/editor/display/layers/cursor.layer.mjs +9 -8
  26. package/esm2022/lib/editor/display/layers/pages.layer.mjs +5 -5
  27. package/esm2022/lib/editor/display/layers/print.text.layer.mjs +2 -2
  28. package/esm2022/lib/editor/display/layers/selection.layer.mjs +15 -9
  29. package/esm2022/lib/editor/display/layers/text.layer.mjs +29 -32
  30. package/esm2022/lib/editor/display/print/print.renderer.mjs +8 -8
  31. package/esm2022/lib/editor/display/renderer.mjs +10 -10
  32. package/esm2022/lib/editor/display/rendering.helper.mjs +2 -4
  33. package/esm2022/lib/editor/display/virtual.renderer.mjs +5 -5
  34. package/esm2022/lib/editor/execution/edit.session.mjs +211 -754
  35. package/esm2022/lib/editor/execution/editor.mjs +119 -77
  36. package/esm2022/lib/editor/execution/helpers/format-style.helper.mjs +41 -32
  37. package/esm2022/lib/editor/execution/helpers/image.helpet.mjs +12 -0
  38. package/esm2022/lib/editor/execution/helpers/paragraph.helper.mjs +11 -3
  39. package/esm2022/lib/editor/execution/regulator.service.mjs +28 -20
  40. package/esm2022/lib/editor/gadgets/numbering/numbering-paragraph-style.model.mjs +13 -0
  41. package/esm2022/lib/editor/gadgets/numbering/numbering.helper.mjs +77 -10
  42. package/esm2022/lib/editor/gadgets/search/search.mjs +6 -6
  43. package/esm2022/lib/editor/interaction/editor.service.mjs +27 -6
  44. package/esm2022/lib/editor/interaction/input.handler.mjs +8 -5
  45. package/esm2022/lib/editor/interaction/mouse.handler.mjs +2 -1
  46. package/esm2022/lib/editor/operations/helpers/format-operations.helper.mjs +32 -2
  47. package/esm2022/lib/editor/operations/helpers/link-operations.helper.mjs +67 -14
  48. package/esm2022/lib/editor/operations/operations-helper.helper.mjs +27 -20
  49. package/esm2022/lib/editor/operations/save-commands.helper.mjs +2 -2
  50. package/esm2022/lib/editor/positioning/content.helper.mjs +15 -15
  51. package/esm2022/lib/editor/positioning/line-width.helper.mjs +5 -5
  52. package/esm2022/lib/editor/positioning/position.helper.mjs +34 -32
  53. package/esm2022/lib/editor/positioning/selection.mjs +42 -32
  54. package/esm2022/lib/editor/revision.helper.mjs +4 -3
  55. package/esm2022/lib/models/generated/link.model.mjs +1 -1
  56. package/esm2022/public-api.mjs +2 -1
  57. package/fesm2022/talrace-ngx-noder.mjs +3863 -3558
  58. package/fesm2022/talrace-ngx-noder.mjs.map +1 -1
  59. package/lib/apart-components/add-link-dialog/add-link-dialog.component.d.ts +0 -1
  60. package/lib/apart-components/editor-toolbar/shared/toolbar-styles.helper.d.ts +0 -2
  61. package/lib/editor/components/image/input-handler/image-input.handler.d.ts +3 -0
  62. package/lib/editor/components/shared/services/custom-content.service.d.ts +3 -5
  63. package/lib/editor/components/table/components/table-cell.component.d.ts +1 -1
  64. package/lib/editor/components/table/components/table.component.d.ts +1 -0
  65. package/lib/editor/components/table/models/cell-data.model.d.ts +1 -1
  66. package/lib/editor/components/table/selection/table-selection.d.ts +2 -0
  67. package/lib/editor/content/constants/editor.const.d.ts +2 -0
  68. package/lib/editor/content/display-data/display-data.d.ts +103 -0
  69. package/lib/editor/content/display-data/general-properties.model.d.ts +5 -0
  70. package/lib/editor/content/display-data/models/paragraph-info.model.d.ts +9 -0
  71. package/lib/editor/content/display-data/paragraph.d.ts +1 -0
  72. package/lib/editor/content/display-data/text-line-info.d.ts +1 -0
  73. package/lib/editor/content/display-data/toolbar-styles.interface.d.ts +1 -1
  74. package/lib/editor/content/helpers/content-style.helper.d.ts +1 -2
  75. package/lib/editor/content/helpers/display-token.helper.d.ts +6 -0
  76. package/lib/editor/content/helpers/link.helper.d.ts +4 -0
  77. package/lib/editor/display/layers/text.layer.d.ts +2 -3
  78. package/lib/editor/display/print/print.renderer.d.ts +0 -2
  79. package/lib/editor/execution/edit.session.d.ts +12 -59
  80. package/lib/editor/execution/editor.d.ts +9 -6
  81. package/lib/editor/execution/helpers/format-style.helper.d.ts +2 -2
  82. package/lib/editor/execution/helpers/image.helpet.d.ts +4 -0
  83. package/lib/editor/execution/regulator.service.d.ts +1 -1
  84. package/lib/editor/gadgets/numbering/numbering-paragraph-style.model.d.ts +6 -0
  85. package/lib/editor/gadgets/numbering/numbering.helper.d.ts +10 -3
  86. package/lib/editor/interaction/editor.service.d.ts +12 -3
  87. package/lib/editor/operations/helpers/link-operations.helper.d.ts +6 -3
  88. package/lib/editor/positioning/content.helper.d.ts +6 -5
  89. package/lib/editor/positioning/position.helper.d.ts +3 -3
  90. package/lib/editor/positioning/selection.d.ts +3 -0
  91. package/lib/models/generated/link.model.d.ts +3 -1
  92. package/package.json +8 -8
  93. package/public-api.d.ts +1 -0
  94. package/src/_ngx-noder.theme.scss +31 -2
  95. package/src/styles.scss +0 -1
  96. package/esm2022/lib/editor/content/display-data/document.mjs +0 -134
  97. package/esm2022/lib/editor/content/display-data/pages.wrap.mjs +0 -226
  98. package/esm2022/lib/editor/execution/helpers/delta.helper.mjs +0 -18
  99. package/lib/editor/content/display-data/document.d.ts +0 -56
  100. package/lib/editor/content/display-data/pages.wrap.d.ts +0 -42
  101. package/lib/editor/execution/helpers/delta.helper.d.ts +0 -6
  102. package/src/scss/_fonts.scss +0 -3
@@ -47,21 +47,27 @@ export class SelectionLayer {
47
47
  }
48
48
  }
49
49
  getTop(row) {
50
- const paragraphs = this.session.pagesWrap.paragraphs;
50
+ const paragraphs = this.session.displayData.paragraphs;
51
51
  const paragraphInfo = PositionHelper.getParagraphInfoByRow(paragraphs, row);
52
- return paragraphs[paragraphInfo.paragraphIndex].distanceFromTop + paragraphInfo.lineTopOffset - this.session.scrollTop;
52
+ return (paragraphs[paragraphInfo.paragraphIndex].paragraphSettings.distanceFromTop +
53
+ paragraphInfo.lineTopOffset -
54
+ this.session.scrollTop);
53
55
  }
54
56
  // Draws a multi line marker, where lines span the full width
55
57
  drawMultiLineMarker(range) {
56
58
  // from selection start to the end of the line
57
59
  const start = range.start.row;
58
60
  const end = range.end.row;
59
- const paragraphs = this.session.pagesWrap.paragraphs;
60
- const visibleParagraphs = paragraphs.filter(x => x.lastScreenLine >= start && x.firstScreenLine <= end);
61
- const textLinesInfo = visibleParagraphs.map(x => x.textLinesInfo.filter(l => start <= l.screenLine && l.screenLine <= end)).flat();
61
+ const paragraphs = this.session.displayData.paragraphs;
62
+ const visibleParagraphs = paragraphs.filter(x => x.paragraphSettings.lastScreenLine >= start && x.paragraphSettings.firstScreenLine <= end);
63
+ const textLinesInfo = visibleParagraphs
64
+ .map(x => x.paragraphSettings.textLinesInfo.filter(l => start <= l.screenLine && l.screenLine <= end))
65
+ .flat();
62
66
  const paragraphInfo = PositionHelper.getParagraphInfoByRow(paragraphs, start);
63
- let top = paragraphs[paragraphInfo.paragraphIndex].distanceFromTop + paragraphInfo.lineTopOffset - this.session.scrollTop;
64
- const padding = this.session.pagesWrap.documentMargin.left;
67
+ let top = paragraphs[paragraphInfo.paragraphIndex].paragraphSettings.distanceFromTop +
68
+ paragraphInfo.lineTopOffset -
69
+ this.session.scrollTop;
70
+ const padding = this.session.displayData.pageMargin.left;
65
71
  for (let i = 0; i < textLinesInfo.length; i++) {
66
72
  const lineInfo = textLinesInfo[i];
67
73
  if (i !== 0) {
@@ -88,7 +94,7 @@ export class SelectionLayer {
88
94
  // Draws a marker which covers part or whole width of a single screen line
89
95
  drawSingleLineMarker(range) {
90
96
  const rangeInfo = this.getRangeInfo(this.session, range);
91
- const paragraphInfo = PositionHelper.getParagraphInfoByRow(this.session.pagesWrap.paragraphs, range.start.row);
97
+ const paragraphInfo = PositionHelper.getParagraphInfoByRow(this.session.displayData.paragraphs, range.start.row);
92
98
  const height = rangeInfo.screenHeight || paragraphInfo.lineHeight;
93
99
  const width = rangeInfo.screenWidth;
94
100
  const top = this.getTop(range.start.row);
@@ -110,4 +116,4 @@ export class SelectionLayer {
110
116
  return `height:${height}px;width:${width}px;top:${top}px;left:${left}px`;
111
117
  }
112
118
  }
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection.layer.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/display/layers/selection.layer.ts"],"names":[],"mappings":"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","sourcesContent":["import { CursorParagraph } from '../../positioning/cursor-paragraph';\nimport { EditSession } from '../../execution/edit.session';\nimport { ILayerConfig } from './layer.config';\nimport { PositionHelper } from '../../positioning/position.helper';\nimport { Range } from '../../positioning/range';\n\nexport class SelectionLayer {\n    element: HTMLElement;\n\n    marker: Range | null = null;\n\n    selectionIndex: number;\n\n    config: ILayerConfig;\n\n    constructor(parentEl: HTMLElement, cssClass: string, private session: EditSession) {\n        this.element = document.createElement('div');\n        this.element.className = `noder-layer noder-selection-layer ${cssClass}`;\n        parentEl.appendChild(this.element);\n    }\n\n    renderSelection(css: string): void {\n        let selectionElement = this.selectionIndex !== -1 ? <HTMLElement>this.element.childNodes[this.selectionIndex] : null;\n        if (!selectionElement) {\n            selectionElement = document.createElement('div');\n            this.element.appendChild(selectionElement);\n            this.selectionIndex = -1;\n        } else {\n            this.selectionIndex++;\n        }\n\n        selectionElement.style.cssText = css;\n        selectionElement.className = 'noder-selection';\n    }\n\n    update(config: ILayerConfig): void {\n        if (!config) {\n            return;\n        }\n\n        this.config = config;\n        this.selectionIndex = 0;\n\n        if (this.marker) {\n            let range = this.marker.clipRows(config.contentRange.start, config.contentRange.end);\n            if (!range.isEmpty) {\n                range = range.toScreenRange(this.session);\n                if (range.isSingleLine) {\n                    this.drawSingleLineMarker(range);\n                } else {\n                    this.drawMultiLineMarker(range);\n                }\n            }\n        }\n\n        if (this.selectionIndex !== -1) {\n            while (this.selectionIndex < this.element.childElementCount) {\n                this.element.removeChild(this.element.lastChild);\n            }\n        }\n    }\n\n    getTop(row: number): number {\n        const paragraphs = this.session.pagesWrap.paragraphs;\n        const paragraphInfo = PositionHelper.getParagraphInfoByRow(paragraphs, row);\n\n        return paragraphs[paragraphInfo.paragraphIndex].distanceFromTop + paragraphInfo.lineTopOffset - this.session.scrollTop;\n    }\n\n    // Draws a multi line marker, where lines span the full width\n    drawMultiLineMarker(range: Range): void {\n        // from selection start to the end of the line\n        const start = range.start.row;\n        const end = range.end.row;\n        const paragraphs = this.session.pagesWrap.paragraphs;\n        const visibleParagraphs = paragraphs.filter(x => x.lastScreenLine >= start && x.firstScreenLine <= end);\n        const textLinesInfo = visibleParagraphs.map(x => x.textLinesInfo.filter(l => start <= l.screenLine && l.screenLine <= end)).flat();\n        const paragraphInfo = PositionHelper.getParagraphInfoByRow(paragraphs, start);\n        let top = paragraphs[paragraphInfo.paragraphIndex].distanceFromTop + paragraphInfo.lineTopOffset - this.session.scrollTop;\n        const padding = this.session.pagesWrap.documentMargin.left;\n        for (let i = 0; i < textLinesInfo.length; i++) {\n            const lineInfo = textLinesInfo[i];\n            if (i !== 0) {\n                top += lineInfo.firstLinePageOffset;\n                top += lineInfo.offsetBefore;\n            }\n\n            let style: string;\n            if (i === 0) {\n                const rangeInfo = this.getRangeInfo(this.session, range);\n                style = this.getMarkerStyle(\n                    lineInfo.height,\n                    lineInfo.width - rangeInfo.leftPos + lineInfo.paddingLeft + padding,\n                    top,\n                    rangeInfo.leftPos\n                );\n            } else if (i === textLinesInfo.length - 1) {\n                const lastRowRange = new Range(new CursorParagraph(range.end.row, 0), range.end);\n                const rangeInfo = this.getRangeInfo(this.session, lastRowRange);\n                style = this.getMarkerStyle(lineInfo.height, rangeInfo.screenWidth, top, padding + lineInfo.paddingLeft);\n            } else {\n                style = this.getMarkerStyle(lineInfo.height, lineInfo.width, top, padding + lineInfo.paddingLeft);\n            }\n\n            this.renderSelection(style);\n            top += lineInfo.height + lineInfo.offsetAfter + lineInfo.endPageOffset;\n        }\n    }\n\n    // Draws a marker which covers part or whole width of a single screen line\n    drawSingleLineMarker(range: Range): void {\n        const rangeInfo = this.getRangeInfo(this.session, range);\n        const paragraphInfo = PositionHelper.getParagraphInfoByRow(this.session.pagesWrap.paragraphs, range.start.row);\n        const height = rangeInfo.screenHeight || paragraphInfo.lineHeight;\n        const width = rangeInfo.screenWidth;\n        const top = this.getTop(range.start.row);\n        const left = rangeInfo.leftPos;\n        this.renderSelection(this.getMarkerStyle(height, width, top, left));\n    }\n\n    private getRangeInfo(session: EditSession, range: Range): { screenWidth: number; screenHeight: number; leftPos: number } {\n        const start = range.start;\n        const end = range.end;\n        const startPos = PositionHelper.screenToPixel(session, start.row, start.column);\n        const endPos = PositionHelper.screenToPixel(session, end.row, end.column);\n\n        return {\n            screenWidth: Math.abs(endPos.pageX - startPos.pageX),\n            screenHeight: Math.abs(endPos.pageY - startPos.pageY),\n            leftPos: startPos.pageX\n        };\n    }\n\n    private getMarkerStyle(height: number, width: number, top: number, left: number): string {\n        return `height:${height}px;width:${width}px;top:${top}px;left:${left}px`;\n    }\n}\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection.layer.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/display/layers/selection.layer.ts"],"names":[],"mappings":"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","sourcesContent":["import { CursorParagraph } from '../../positioning/cursor-paragraph';\nimport { EditSession } from '../../execution/edit.session';\nimport { ILayerConfig } from './layer.config';\nimport { PositionHelper } from '../../positioning/position.helper';\nimport { Range } from '../../positioning/range';\n\nexport class SelectionLayer {\n    element: HTMLElement;\n\n    marker: Range | null = null;\n\n    selectionIndex: number;\n\n    config: ILayerConfig;\n\n    constructor(parentEl: HTMLElement, cssClass: string, private session: EditSession) {\n        this.element = document.createElement('div');\n        this.element.className = `noder-layer noder-selection-layer ${cssClass}`;\n        parentEl.appendChild(this.element);\n    }\n\n    renderSelection(css: string): void {\n        let selectionElement = this.selectionIndex !== -1 ? <HTMLElement>this.element.childNodes[this.selectionIndex] : null;\n        if (!selectionElement) {\n            selectionElement = document.createElement('div');\n            this.element.appendChild(selectionElement);\n            this.selectionIndex = -1;\n        } else {\n            this.selectionIndex++;\n        }\n\n        selectionElement.style.cssText = css;\n        selectionElement.className = 'noder-selection';\n    }\n\n    update(config: ILayerConfig): void {\n        if (!config) {\n            return;\n        }\n\n        this.config = config;\n        this.selectionIndex = 0;\n\n        if (this.marker) {\n            let range = this.marker.clipRows(config.contentRange.start, config.contentRange.end);\n            if (!range.isEmpty) {\n                range = range.toScreenRange(this.session);\n                if (range.isSingleLine) {\n                    this.drawSingleLineMarker(range);\n                } else {\n                    this.drawMultiLineMarker(range);\n                }\n            }\n        }\n\n        if (this.selectionIndex !== -1) {\n            while (this.selectionIndex < this.element.childElementCount) {\n                this.element.removeChild(this.element.lastChild);\n            }\n        }\n    }\n\n    getTop(row: number): number {\n        const paragraphs = this.session.displayData.paragraphs;\n        const paragraphInfo = PositionHelper.getParagraphInfoByRow(paragraphs, row);\n\n        return (\n            paragraphs[paragraphInfo.paragraphIndex].paragraphSettings.distanceFromTop +\n            paragraphInfo.lineTopOffset -\n            this.session.scrollTop\n        );\n    }\n\n    // Draws a multi line marker, where lines span the full width\n    drawMultiLineMarker(range: Range): void {\n        // from selection start to the end of the line\n        const start = range.start.row;\n        const end = range.end.row;\n        const paragraphs = this.session.displayData.paragraphs;\n        const visibleParagraphs = paragraphs.filter(\n            x => x.paragraphSettings.lastScreenLine >= start && x.paragraphSettings.firstScreenLine <= end\n        );\n        const textLinesInfo = visibleParagraphs\n            .map(x => x.paragraphSettings.textLinesInfo.filter(l => start <= l.screenLine && l.screenLine <= end))\n            .flat();\n        const paragraphInfo = PositionHelper.getParagraphInfoByRow(paragraphs, start);\n        let top =\n            paragraphs[paragraphInfo.paragraphIndex].paragraphSettings.distanceFromTop +\n            paragraphInfo.lineTopOffset -\n            this.session.scrollTop;\n        const padding = this.session.displayData.pageMargin.left;\n        for (let i = 0; i < textLinesInfo.length; i++) {\n            const lineInfo = textLinesInfo[i];\n            if (i !== 0) {\n                top += lineInfo.firstLinePageOffset;\n                top += lineInfo.offsetBefore;\n            }\n\n            let style: string;\n            if (i === 0) {\n                const rangeInfo = this.getRangeInfo(this.session, range);\n                style = this.getMarkerStyle(\n                    lineInfo.height,\n                    lineInfo.width - rangeInfo.leftPos + lineInfo.paddingLeft + padding,\n                    top,\n                    rangeInfo.leftPos\n                );\n            } else if (i === textLinesInfo.length - 1) {\n                const lastRowRange = new Range(new CursorParagraph(range.end.row, 0), range.end);\n                const rangeInfo = this.getRangeInfo(this.session, lastRowRange);\n                style = this.getMarkerStyle(lineInfo.height, rangeInfo.screenWidth, top, padding + lineInfo.paddingLeft);\n            } else {\n                style = this.getMarkerStyle(lineInfo.height, lineInfo.width, top, padding + lineInfo.paddingLeft);\n            }\n\n            this.renderSelection(style);\n            top += lineInfo.height + lineInfo.offsetAfter + lineInfo.endPageOffset;\n        }\n    }\n\n    // Draws a marker which covers part or whole width of a single screen line\n    drawSingleLineMarker(range: Range): void {\n        const rangeInfo = this.getRangeInfo(this.session, range);\n        const paragraphInfo = PositionHelper.getParagraphInfoByRow(this.session.displayData.paragraphs, range.start.row);\n        const height = rangeInfo.screenHeight || paragraphInfo.lineHeight;\n        const width = rangeInfo.screenWidth;\n        const top = this.getTop(range.start.row);\n        const left = rangeInfo.leftPos;\n        this.renderSelection(this.getMarkerStyle(height, width, top, left));\n    }\n\n    private getRangeInfo(session: EditSession, range: Range): { screenWidth: number; screenHeight: number; leftPos: number } {\n        const start = range.start;\n        const end = range.end;\n        const startPos = PositionHelper.screenToPixel(session, start.row, start.column);\n        const endPos = PositionHelper.screenToPixel(session, end.row, end.column);\n\n        return {\n            screenWidth: Math.abs(endPos.pageX - startPos.pageX),\n            screenHeight: Math.abs(endPos.pageY - startPos.pageY),\n            leftPos: startPos.pageX\n        };\n    }\n\n    private getMarkerStyle(height: number, width: number, top: number, left: number): string {\n        return `height:${height}px;width:${width}px;top:${top}px;left:${left}px`;\n    }\n}\n"]}
@@ -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,30 @@ 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;
182
- const formats = FormatStyleHelper.getFormatsAtRange(this.session.model.formats, startIndex, endIndex);
183
- const splits = this.session.wrapData[row];
184
- const formatsExt = formats.map(format => new FormatExtModel({
185
- ...format,
186
- content: this.session.model.content.substring(format.startIndex, format.endIndex + 1)
178
+ const startIndex = this.session.displayData.positionToIndex({ row, column: 0 });
179
+ const endIndex = this.session.displayData.positionToIndex({ row: row + 1, column: 0 }) - 1;
180
+ const combinedFormats = FormatStyleHelper.combineSection(this.session.model.formats, this.session.model.links, startIndex, endIndex).map(x => new FormatExtModel({
181
+ ...x,
182
+ content: this.session.model.content.substring(x.startIndex, x.endIndex + 1)
187
183
  }));
184
+ const splits = this.session.displayData.paragraphs[row].nextLineIndexes;
188
185
  if (splits?.length) {
189
186
  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);
187
+ this.renderingHelper.renderContentWrappedLine({ currentElement: this.element, parentNode: linesContainerElement }, splits, paragraphSettings, combinedFormats, distance, this.session.customContentService, this.session.customComponents, this.session.generalProperties.scalingRatio, this.session.model.breaks);
191
188
  }
192
189
  else {
193
- const numberingOffsetLeft = currentParagraph.numberingData.numberingId === null
190
+ const numberingOffsetLeft = paragraphSettings.numberingData.numberingId === null
194
191
  ? 0
195
- : currentParagraph.numberingData.width + currentParagraph.numberingData.paddingLeft;
196
- const lastLineEl = this.renderingHelper.createLineElement(currentParagraph.textLinesInfo[0], numberingOffsetLeft, this.session.generalProperties.scalingRatio);
192
+ : paragraphSettings.numberingData.width + paragraphSettings.numberingData.paddingLeft;
193
+ const lastLineEl = this.renderingHelper.createLineElement(paragraphSettings.textLinesInfo[0], numberingOffsetLeft, this.session.generalProperties.scalingRatio);
197
194
  linesContainerElement.appendChild(lastLineEl);
198
195
  const rowDistance = new DistanceModel({ start: startIndex, end: endIndex });
199
- this.renderingHelper.renderContentSimpleLine({ currentElement: this.element, parentNode: lastLineEl }, formatsExt, rowDistance, this.session.customContentService, this.session.customComponents, this.session.model.breaks);
196
+ this.renderingHelper.renderContentSimpleLine({ currentElement: this.element, parentNode: lastLineEl }, combinedFormats, rowDistance, this.session.customContentService, this.session.customComponents, this.session.model.breaks);
200
197
  }
201
198
  }
202
199
  }
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"]}
200
+ //# 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 { EditorService } from '../../interaction/editor.service';\nimport { EditSession } from '../../execution/edit.session';\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 combinedFormats = FormatStyleHelper.combineSection(\n            this.session.model.formats,\n            this.session.model.links,\n            startIndex,\n            endIndex\n        ).map(\n            x =>\n                new FormatExtModel({\n                    ...x,\n                    content: this.session.model.content.substring(x.startIndex, x.endIndex + 1)\n                })\n        );\n        const splits = this.session.displayData.paragraphs[row].nextLineIndexes;\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                combinedFormats,\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                combinedFormats,\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":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAM/D,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D,MAAM,OAAO,aAAa;IAetB,YAAoB,WAAwB,EAAE,aAA4B;QAAtD,gBAAW,GAAX,WAAW,CAAa;QACxC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CACxB,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,GAAG,CAAC,GAAG,WAAW,CAAC,SAAS,CAAC,cAAc,CAAC,GAAG,WAAW,CAAC,SAAS,CAAC,SAAS,CAClH,CAAC;QACF,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IACrC,CAAC;IAED,mBAAmB;QACf,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE9C,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;QACpC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QACxC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAExC,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC;IAEO,kBAAkB;QACtB,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACxE,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC;QAC7C,MAAM,SAAS,GAAG,SAAS,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QACzD,MAAM,SAAS,GAAG,SAAS,CAAC,UAAU,CAAC;QAEvC,OAAO;YACH,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC,cAAc,CAAC,IAAI,GAAG,SAAS,CAAC,cAAc,CAAC,KAAK;YAC1G,MAAM,EAAE,SAAS,CAAC,mBAAmB,CAAC,aAAa;YACnD,YAAY,EAAE,IAAI,aAAa,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpG,SAAS;YACT,SAAS;YACT,MAAM,EAAE,CAAC;YACT,KAAK;YACL,SAAS,EAAE,CAAC;SACf,CAAC;IACN,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC7C,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,qBAAqB,CAAC;IACnD,CAAC;IAEO,YAAY,CAAC,aAA4B;QAC7C,IAAI,CAAC,SAAS,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,aAAa,EAAE,oBAAoB,CAAC,CAAC;QACzG,IAAI,CAAC,UAAU,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IAC1E,CAAC;IAEO,kBAAkB,CAAC,WAAyB;QAChD,MAAM,IAAI,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACzC,IAAI,IAAI,GAAG,0DAA0D,IAAI,CAAC,OAAO,CAAC,SAAS,QAAQ,CAAC;QACpG,IAAI,GAAG,kDAAkD,IAAI,QAAQ,CAAC;QACtE,IAAI,GAAG,+CAA+C,WAAW,CAAC,SAAS,QAAQ,IAAI,QAAQ,CAAC;QAChG,IAAI,GAAG,yCAAyC,IAAI,QAAQ,CAAC;QAC7D,IAAI,GAAG,6DAA6D,IAAI,QAAQ,CAAC;QACjF,IAAI,GAAG,kCAAkC,IAAI,QAAQ,CAAC;QAEtD,IAAI,CAAC,YAAY,GAAG,wBAAwB,IAAI,GAAG,IAAI,SAAS,CAAC;IACrE,CAAC;IAEO,oBAAoB;QACxB,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAClD,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;YAC9D,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,MAAM,IAAI,UAAU,IAAI,CAAC,OAAO,UAAU,CAAC,CAAC,CAAC;SAC1E;QAED,OAAO,6BAA6B,MAAM,GAAG,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC;IACnF,CAAC;IAEO,iBAAiB;QACrB,MAAM,SAAS,GAAG,sBAAsB,CAAC;QACzC,MAAM,YAAY,GAAG,4DAA4D,CAAC;QAClF,OAAO,UAAU,SAAS,IAAI,YAAY,UAAU,CAAC;IACzD,CAAC;CACJ","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":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAK/D,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D,MAAM,OAAO,aAAa;IAatB,YAAoB,WAAwB,EAAE,aAA4B;QAAtD,gBAAW,GAAX,WAAW,CAAa;QACxC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CACxB,CAAC,WAAW,CAAC,WAAW,CAAC,UAAU,GAAG,CAAC,GAAG,WAAW,CAAC,WAAW,CAAC,cAAc,CAAC,GAAG,WAAW,CAAC,WAAW,CAAC,SAAS,CACxH,CAAC;QACF,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IACrC,CAAC;IAED,mBAAmB;QACf,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE9C,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;QACpC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QACxC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAExC,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC;IAEO,kBAAkB;QACtB,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACxE,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC;QACjD,MAAM,SAAS,GAAG,WAAW,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAC3D,MAAM,SAAS,GAAG,WAAW,CAAC,UAAU,CAAC;QAEzC,OAAO;YACH,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,WAAW,GAAG,WAAW,CAAC,UAAU,CAAC,IAAI,GAAG,WAAW,CAAC,UAAU,CAAC,KAAK;YACtG,MAAM,EAAE,WAAW,CAAC,mBAAmB,CAAC,aAAa;YACrD,YAAY,EAAE,IAAI,aAAa,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,WAAW,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACrF,SAAS;YACT,SAAS;YACT,MAAM,EAAE,CAAC;YACT,KAAK;YACL,SAAS,EAAE,CAAC;SACf,CAAC;IACN,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC7C,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,qBAAqB,CAAC;IACnD,CAAC;IAEO,YAAY,CAAC,aAA4B;QAC7C,IAAI,CAAC,SAAS,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,aAAa,EAAE,oBAAoB,CAAC,CAAC;QACzG,IAAI,CAAC,UAAU,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IAC1E,CAAC;IAEO,kBAAkB,CAAC,WAAyB;QAChD,MAAM,IAAI,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACzC,IAAI,IAAI,GAAG,0DAA0D,IAAI,CAAC,OAAO,CAAC,SAAS,QAAQ,CAAC;QACpG,IAAI,GAAG,kDAAkD,IAAI,QAAQ,CAAC;QACtE,IAAI,GAAG,+CAA+C,WAAW,CAAC,SAAS,QAAQ,IAAI,QAAQ,CAAC;QAChG,IAAI,GAAG,yCAAyC,IAAI,QAAQ,CAAC;QAC7D,IAAI,GAAG,6DAA6D,IAAI,QAAQ,CAAC;QACjF,IAAI,GAAG,kCAAkC,IAAI,QAAQ,CAAC;QAEtD,IAAI,CAAC,YAAY,GAAG,wBAAwB,IAAI,GAAG,IAAI,SAAS,CAAC;IACrE,CAAC;IAEO,oBAAoB;QACxB,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAClD,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;YAC9D,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,MAAM,IAAI,UAAU,IAAI,CAAC,OAAO,UAAU,CAAC,CAAC,CAAC;SAC1E;QAED,OAAO,6BAA6B,MAAM,GAAG,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC;IACnF,CAAC;IAEO,iBAAiB;QACrB,MAAM,SAAS,GAAG,sBAAsB,CAAC;QACzC,MAAM,YAAY,GAAG,4DAA4D,CAAC;QAClF,OAAO,UAAU,SAAS,IAAI,YAAY,UAAU,CAAC;IACzD,CAAC;CACJ","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"]}