handsontable 0.0.0-next-eaf150e-20240823 → 0.0.0-next-0306a1a-20240826

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of handsontable might be problematic. Click here for more details.

Files changed (104) hide show
  1. package/3rdparty/walkontable/src/calculator/constants.js +26 -0
  2. package/3rdparty/walkontable/src/calculator/constants.mjs +23 -0
  3. package/3rdparty/walkontable/src/calculator/index.js +17 -18
  4. package/3rdparty/walkontable/src/calculator/index.mjs +6 -11
  5. package/3rdparty/walkontable/src/calculator/{calculationType/renderedAllColumns.js → renderAllColumns.js} +9 -32
  6. package/3rdparty/walkontable/src/calculator/{calculationType/renderedAllColumns.mjs → renderAllColumns.mjs} +8 -31
  7. package/3rdparty/walkontable/src/calculator/{calculationType/renderedAllRows.js → renderAllRows.js} +9 -32
  8. package/3rdparty/walkontable/src/calculator/{calculationType/renderedAllRows.mjs → renderAllRows.mjs} +8 -31
  9. package/3rdparty/walkontable/src/calculator/viewportColumns.js +145 -51
  10. package/3rdparty/walkontable/src/calculator/viewportColumns.mjs +145 -51
  11. package/3rdparty/walkontable/src/calculator/viewportRows.js +141 -59
  12. package/3rdparty/walkontable/src/calculator/viewportRows.mjs +141 -59
  13. package/3rdparty/walkontable/src/index.js +0 -2
  14. package/3rdparty/walkontable/src/index.mjs +2 -2
  15. package/3rdparty/walkontable/src/table.js +11 -5
  16. package/3rdparty/walkontable/src/table.mjs +11 -5
  17. package/3rdparty/walkontable/src/utils/column.js +1 -2
  18. package/3rdparty/walkontable/src/utils/column.mjs +1 -2
  19. package/3rdparty/walkontable/src/utils/columnStretching.js +19 -10
  20. package/3rdparty/walkontable/src/utils/columnStretching.mjs +19 -10
  21. package/3rdparty/walkontable/src/viewport.js +46 -35
  22. package/3rdparty/walkontable/src/viewport.mjs +47 -36
  23. package/CHANGELOG.md +0 -27
  24. package/base.js +2 -2
  25. package/base.mjs +2 -2
  26. package/core.d.ts +2 -1
  27. package/core.js +1 -1
  28. package/core.mjs +2 -2
  29. package/dataMap/metaManager/metaSchema.js +6 -5
  30. package/dataMap/metaManager/metaSchema.mjs +6 -5
  31. package/dist/handsontable.css +20 -32
  32. package/dist/handsontable.full.css +20 -32
  33. package/dist/handsontable.full.js +2091 -2741
  34. package/dist/handsontable.full.min.css +5 -5
  35. package/dist/handsontable.full.min.js +148 -148
  36. package/dist/handsontable.js +2092 -2742
  37. package/dist/handsontable.min.css +4 -4
  38. package/dist/handsontable.min.js +32 -32
  39. package/editors/autocompleteEditor/autocompleteEditor.d.ts +1 -1
  40. package/helpers/a11y.js +0 -2
  41. package/helpers/a11y.mjs +0 -1
  42. package/helpers/mixed.js +2 -2
  43. package/helpers/mixed.mjs +2 -2
  44. package/package.json +1 -1
  45. package/pluginHooks.d.ts +1 -1
  46. package/pluginHooks.js +1 -1
  47. package/pluginHooks.mjs +1 -1
  48. package/plugins/autoColumnSize/autoColumnSize.js +1 -1
  49. package/plugins/autoColumnSize/autoColumnSize.mjs +2 -2
  50. package/plugins/autoRowSize/autoRowSize.js +2 -1
  51. package/plugins/autoRowSize/autoRowSize.mjs +2 -1
  52. package/plugins/columnSorting/columnSorting.js +1 -10
  53. package/plugins/columnSorting/columnSorting.mjs +1 -10
  54. package/plugins/contextMenu/menu/menuItemRenderer.js +4 -3
  55. package/plugins/contextMenu/menu/menuItemRenderer.mjs +6 -5
  56. package/plugins/contextMenu/menu/positioner.js +12 -4
  57. package/plugins/contextMenu/menu/positioner.mjs +12 -4
  58. package/plugins/contextMenu/menu/utils.js +0 -11
  59. package/plugins/contextMenu/menu/utils.mjs +0 -10
  60. package/plugins/contextMenu/predefinedItems/alignment.js +49 -67
  61. package/plugins/contextMenu/predefinedItems/alignment.mjs +50 -68
  62. package/plugins/contextMenu/predefinedItems/readOnly.js +0 -11
  63. package/plugins/contextMenu/predefinedItems/readOnly.mjs +0 -11
  64. package/plugins/contextMenu/utils.js +0 -26
  65. package/plugins/contextMenu/utils.mjs +0 -24
  66. package/plugins/copyPaste/copyPaste.js +14 -14
  67. package/plugins/copyPaste/copyPaste.mjs +14 -14
  68. package/plugins/dropdownMenu/dropdownMenu.js +4 -10
  69. package/plugins/dropdownMenu/dropdownMenu.mjs +4 -10
  70. package/plugins/filters/component/condition.js +1 -6
  71. package/plugins/filters/component/condition.mjs +1 -6
  72. package/plugins/filters/component/value.js +1 -6
  73. package/plugins/filters/component/value.mjs +1 -6
  74. package/plugins/filters/conditionCollection.d.ts +3 -4
  75. package/plugins/filters/conditionCollection.js +0 -26
  76. package/plugins/filters/conditionCollection.mjs +0 -26
  77. package/plugins/filters/filters.js +1 -2
  78. package/plugins/filters/filters.mjs +1 -2
  79. package/plugins/filters/ui/multipleSelect.js +9 -7
  80. package/plugins/filters/ui/multipleSelect.mjs +9 -7
  81. package/plugins/manualRowResize/manualRowResize.js +1 -1
  82. package/plugins/manualRowResize/manualRowResize.mjs +2 -2
  83. package/plugins/mergeCells/cellsCollection.js +9 -11
  84. package/plugins/mergeCells/cellsCollection.mjs +10 -12
  85. package/plugins/undoRedo/undoRedo.js +5 -9
  86. package/plugins/undoRedo/undoRedo.mjs +5 -9
  87. package/shortcuts/utils.js +1 -3
  88. package/shortcuts/utils.mjs +1 -3
  89. package/utils/ghostTable.js +9 -11
  90. package/utils/ghostTable.mjs +10 -12
  91. package/3rdparty/walkontable/src/calculator/calculationType/fullyVisibleColumns.js +0 -126
  92. package/3rdparty/walkontable/src/calculator/calculationType/fullyVisibleColumns.mjs +0 -122
  93. package/3rdparty/walkontable/src/calculator/calculationType/fullyVisibleRows.js +0 -119
  94. package/3rdparty/walkontable/src/calculator/calculationType/fullyVisibleRows.mjs +0 -115
  95. package/3rdparty/walkontable/src/calculator/calculationType/partiallyVisibleColumns.js +0 -125
  96. package/3rdparty/walkontable/src/calculator/calculationType/partiallyVisibleColumns.mjs +0 -121
  97. package/3rdparty/walkontable/src/calculator/calculationType/partiallyVisibleRows.js +0 -118
  98. package/3rdparty/walkontable/src/calculator/calculationType/partiallyVisibleRows.mjs +0 -114
  99. package/3rdparty/walkontable/src/calculator/calculationType/renderedColumns.js +0 -37
  100. package/3rdparty/walkontable/src/calculator/calculationType/renderedColumns.mjs +0 -33
  101. package/3rdparty/walkontable/src/calculator/calculationType/renderedRows.js +0 -37
  102. package/3rdparty/walkontable/src/calculator/calculationType/renderedRows.mjs +0 -33
  103. package/3rdparty/walkontable/src/calculator/viewportBase.js +0 -92
  104. package/3rdparty/walkontable/src/calculator/viewportBase.mjs +0 -88
@@ -1,122 +0,0 @@
1
- import "core-js/modules/es.error.cause.js";
2
- import "core-js/modules/es.array.at.js";
3
- import "core-js/modules/es.string.at-alternative.js";
4
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
5
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
6
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
- /**
8
- * @class FullyVisibleColumnsCalculationType
9
- */
10
- export class FullyVisibleColumnsCalculationType {
11
- constructor() {
12
- /**
13
- * Total number of fully visible columns in the viewport.
14
- *
15
- * @type {number}
16
- */
17
- _defineProperty(this, "count", 0);
18
- /**
19
- * The column index of the first fully visible column in the viewport.
20
- *
21
- * @type {number|null}
22
- */
23
- _defineProperty(this, "startColumn", null);
24
- /**
25
- * The column index of the last fully visible column in the viewport.
26
- *
27
- * @type {number|null}
28
- */
29
- _defineProperty(this, "endColumn", null);
30
- /**
31
- * Position of the first fully visible column (in px).
32
- *
33
- * @type {number|null}
34
- */
35
- _defineProperty(this, "startPosition", null);
36
- /**
37
- * Determines if the viewport is visible in the trimming container.
38
- *
39
- * @type {boolean}
40
- */
41
- _defineProperty(this, "isVisibleInTrimmingContainer", false);
42
- }
43
- /**
44
- * Initializes the calculation.
45
- */
46
- initialize() {}
47
-
48
- /**
49
- * Processes the column.
50
- *
51
- * @param {number} column The column index.
52
- * @param {ViewportColumnsCalculator} viewportCalculator The viewport calculator object.
53
- */
54
- process(column, viewportCalculator) {
55
- const {
56
- totalCalculatedWidth,
57
- zeroBasedScrollOffset,
58
- viewportWidth,
59
- columnWidth
60
- } = viewportCalculator;
61
- const compensatedViewportWidth = zeroBasedScrollOffset > 0 ? viewportWidth + 1 : viewportWidth;
62
- if (totalCalculatedWidth >= zeroBasedScrollOffset && totalCalculatedWidth + columnWidth <= zeroBasedScrollOffset + compensatedViewportWidth) {
63
- if (this.startColumn === null || this.startColumn === undefined) {
64
- this.startColumn = column;
65
- }
66
- this.endColumn = column;
67
- }
68
- }
69
-
70
- /**
71
- * Finalizes the calculation.
72
- *
73
- * @param {ViewportColumnsCalculator} viewportCalculator The viewport calculator object.
74
- */
75
- finalize(viewportCalculator) {
76
- var _startPositions$this$;
77
- const {
78
- scrollOffset,
79
- viewportWidth,
80
- inlineStartOffset,
81
- zeroBasedScrollOffset,
82
- totalColumns,
83
- needReverse,
84
- startPositions,
85
- columnWidth
86
- } = viewportCalculator;
87
-
88
- // If the estimation has reached the last column and there is still some space available in the viewport,
89
- // we need to render in reverse in order to fill the whole viewport with columns
90
- if (this.endColumn === totalColumns - 1 && needReverse) {
91
- this.startColumn = this.endColumn;
92
- while (this.startColumn > 0) {
93
- const calculatedViewportHeight = startPositions[this.endColumn] + columnWidth - startPositions[this.startColumn - 1];
94
- if (calculatedViewportHeight <= viewportWidth) {
95
- this.startColumn -= 1;
96
- }
97
- if (calculatedViewportHeight >= viewportWidth) {
98
- break;
99
- }
100
- }
101
- }
102
- this.startPosition = (_startPositions$this$ = startPositions[this.startColumn]) !== null && _startPositions$this$ !== void 0 ? _startPositions$this$ : null;
103
- const compensatedViewportWidth = zeroBasedScrollOffset > 0 ? viewportWidth + 1 : viewportWidth;
104
- const mostRightScrollOffset = scrollOffset + viewportWidth - compensatedViewportWidth;
105
- const inlineStartColumnOffset = this.startColumn === null ? 0 : viewportCalculator.getColumnWidth(this.startColumn);
106
- if (
107
- // the table is to the left of the viewport
108
- mostRightScrollOffset < -1 * inlineStartOffset || scrollOffset > startPositions.at(-1) ||
109
- // the table is to the right of the viewport
110
- -1 * scrollOffset - viewportWidth > -1 * inlineStartColumnOffset) {
111
- this.isVisibleInTrimmingContainer = false;
112
- } else {
113
- this.isVisibleInTrimmingContainer = true;
114
- }
115
- if (totalColumns < this.endColumn) {
116
- this.endColumn = totalColumns - 1;
117
- }
118
- if (this.startColumn !== null) {
119
- this.count = this.endColumn - this.startColumn + 1;
120
- }
121
- }
122
- }
@@ -1,119 +0,0 @@
1
- "use strict";
2
-
3
- exports.__esModule = true;
4
- require("core-js/modules/es.error.cause.js");
5
- require("core-js/modules/es.array.at.js");
6
- require("core-js/modules/es.string.at-alternative.js");
7
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
8
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
9
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
10
- /**
11
- * @class FullyVisibleRowsCalculationType
12
- */
13
- class FullyVisibleRowsCalculationType {
14
- constructor() {
15
- /**
16
- * Total number of fully visible rows in the viewport.
17
- *
18
- * @type {number}
19
- */
20
- _defineProperty(this, "count", 0);
21
- /**
22
- * The row index of the first fully visible row in the viewport.
23
- *
24
- * @type {number|null}
25
- */
26
- _defineProperty(this, "startRow", null);
27
- /**
28
- * The row index of the last fully visible row in the viewport.
29
- *
30
- * @type {number|null}
31
- */
32
- _defineProperty(this, "endRow", null);
33
- /**
34
- * Position of the first fully visible row (in px).
35
- *
36
- * @type {number|null}
37
- */
38
- _defineProperty(this, "startPosition", null);
39
- /**
40
- * Determines if the viewport is visible in the trimming container.
41
- *
42
- * @type {boolean}
43
- */
44
- _defineProperty(this, "isVisibleInTrimmingContainer", false);
45
- }
46
- /**
47
- * Initializes the calculation.
48
- */
49
- initialize() {}
50
-
51
- /**
52
- * Processes the row.
53
- *
54
- * @param {number} row The row index.
55
- * @param {ViewportRowsCalculator} viewportCalculator The viewport calculator object.
56
- */
57
- process(row, viewportCalculator) {
58
- const {
59
- totalCalculatedHeight,
60
- zeroBasedScrollOffset,
61
- innerViewportHeight,
62
- rowHeight
63
- } = viewportCalculator;
64
- if (totalCalculatedHeight >= zeroBasedScrollOffset && totalCalculatedHeight + rowHeight <= innerViewportHeight) {
65
- if (this.startRow === null) {
66
- this.startRow = row;
67
- }
68
- this.endRow = row;
69
- }
70
- }
71
-
72
- /**
73
- * Finalizes the calculation.
74
- *
75
- * @param {ViewportRowsCalculator} viewportCalculator The viewport calculator object.
76
- */
77
- finalize(viewportCalculator) {
78
- var _startPositions$this$;
79
- const {
80
- scrollOffset,
81
- viewportHeight,
82
- horizontalScrollbarHeight,
83
- totalRows,
84
- needReverse,
85
- startPositions,
86
- rowHeight
87
- } = viewportCalculator;
88
-
89
- // If the estimation has reached the last row and there is still some space available in the viewport,
90
- // we need to render in reverse in order to fill the whole viewport with rows
91
- if (this.endRow === totalRows - 1 && needReverse) {
92
- this.startRow = this.endRow;
93
- while (this.startRow > 0) {
94
- const calculatedViewportHeight = startPositions[this.endRow] + rowHeight - startPositions[this.startRow - 1];
95
- if (calculatedViewportHeight <= viewportHeight - horizontalScrollbarHeight) {
96
- this.startRow -= 1;
97
- }
98
- if (calculatedViewportHeight >= viewportHeight - horizontalScrollbarHeight) {
99
- break;
100
- }
101
- }
102
- }
103
- this.startPosition = (_startPositions$this$ = startPositions[this.startRow]) !== null && _startPositions$this$ !== void 0 ? _startPositions$this$ : null;
104
- const mostBottomScrollOffset = scrollOffset + viewportHeight - horizontalScrollbarHeight;
105
- const topRowOffset = this.startRow === null ? 0 : viewportCalculator.getRowHeight(this.startRow);
106
- if (mostBottomScrollOffset < topRowOffset || scrollOffset > startPositions.at(-1)) {
107
- this.isVisibleInTrimmingContainer = false;
108
- } else {
109
- this.isVisibleInTrimmingContainer = true;
110
- }
111
- if (totalRows < this.endRow) {
112
- this.endRow = totalRows - 1;
113
- }
114
- if (this.startRow !== null) {
115
- this.count = this.endRow - this.startRow + 1;
116
- }
117
- }
118
- }
119
- exports.FullyVisibleRowsCalculationType = FullyVisibleRowsCalculationType;
@@ -1,115 +0,0 @@
1
- import "core-js/modules/es.error.cause.js";
2
- import "core-js/modules/es.array.at.js";
3
- import "core-js/modules/es.string.at-alternative.js";
4
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
5
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
6
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
- /**
8
- * @class FullyVisibleRowsCalculationType
9
- */
10
- export class FullyVisibleRowsCalculationType {
11
- constructor() {
12
- /**
13
- * Total number of fully visible rows in the viewport.
14
- *
15
- * @type {number}
16
- */
17
- _defineProperty(this, "count", 0);
18
- /**
19
- * The row index of the first fully visible row in the viewport.
20
- *
21
- * @type {number|null}
22
- */
23
- _defineProperty(this, "startRow", null);
24
- /**
25
- * The row index of the last fully visible row in the viewport.
26
- *
27
- * @type {number|null}
28
- */
29
- _defineProperty(this, "endRow", null);
30
- /**
31
- * Position of the first fully visible row (in px).
32
- *
33
- * @type {number|null}
34
- */
35
- _defineProperty(this, "startPosition", null);
36
- /**
37
- * Determines if the viewport is visible in the trimming container.
38
- *
39
- * @type {boolean}
40
- */
41
- _defineProperty(this, "isVisibleInTrimmingContainer", false);
42
- }
43
- /**
44
- * Initializes the calculation.
45
- */
46
- initialize() {}
47
-
48
- /**
49
- * Processes the row.
50
- *
51
- * @param {number} row The row index.
52
- * @param {ViewportRowsCalculator} viewportCalculator The viewport calculator object.
53
- */
54
- process(row, viewportCalculator) {
55
- const {
56
- totalCalculatedHeight,
57
- zeroBasedScrollOffset,
58
- innerViewportHeight,
59
- rowHeight
60
- } = viewportCalculator;
61
- if (totalCalculatedHeight >= zeroBasedScrollOffset && totalCalculatedHeight + rowHeight <= innerViewportHeight) {
62
- if (this.startRow === null) {
63
- this.startRow = row;
64
- }
65
- this.endRow = row;
66
- }
67
- }
68
-
69
- /**
70
- * Finalizes the calculation.
71
- *
72
- * @param {ViewportRowsCalculator} viewportCalculator The viewport calculator object.
73
- */
74
- finalize(viewportCalculator) {
75
- var _startPositions$this$;
76
- const {
77
- scrollOffset,
78
- viewportHeight,
79
- horizontalScrollbarHeight,
80
- totalRows,
81
- needReverse,
82
- startPositions,
83
- rowHeight
84
- } = viewportCalculator;
85
-
86
- // If the estimation has reached the last row and there is still some space available in the viewport,
87
- // we need to render in reverse in order to fill the whole viewport with rows
88
- if (this.endRow === totalRows - 1 && needReverse) {
89
- this.startRow = this.endRow;
90
- while (this.startRow > 0) {
91
- const calculatedViewportHeight = startPositions[this.endRow] + rowHeight - startPositions[this.startRow - 1];
92
- if (calculatedViewportHeight <= viewportHeight - horizontalScrollbarHeight) {
93
- this.startRow -= 1;
94
- }
95
- if (calculatedViewportHeight >= viewportHeight - horizontalScrollbarHeight) {
96
- break;
97
- }
98
- }
99
- }
100
- this.startPosition = (_startPositions$this$ = startPositions[this.startRow]) !== null && _startPositions$this$ !== void 0 ? _startPositions$this$ : null;
101
- const mostBottomScrollOffset = scrollOffset + viewportHeight - horizontalScrollbarHeight;
102
- const topRowOffset = this.startRow === null ? 0 : viewportCalculator.getRowHeight(this.startRow);
103
- if (mostBottomScrollOffset < topRowOffset || scrollOffset > startPositions.at(-1)) {
104
- this.isVisibleInTrimmingContainer = false;
105
- } else {
106
- this.isVisibleInTrimmingContainer = true;
107
- }
108
- if (totalRows < this.endRow) {
109
- this.endRow = totalRows - 1;
110
- }
111
- if (this.startRow !== null) {
112
- this.count = this.endRow - this.startRow + 1;
113
- }
114
- }
115
- }
@@ -1,125 +0,0 @@
1
- "use strict";
2
-
3
- exports.__esModule = true;
4
- require("core-js/modules/es.error.cause.js");
5
- require("core-js/modules/es.array.at.js");
6
- require("core-js/modules/es.string.at-alternative.js");
7
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
8
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
9
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
10
- /**
11
- * @class PartiallyVisibleColumnsCalculationType
12
- */
13
- class PartiallyVisibleColumnsCalculationType {
14
- constructor() {
15
- /**
16
- * Total number of partially visible columns in the viewport.
17
- *
18
- * @type {number}
19
- */
20
- _defineProperty(this, "count", 0);
21
- /**
22
- * The column index of the first partially visible column in the viewport.
23
- *
24
- * @type {number|null}
25
- */
26
- _defineProperty(this, "startColumn", null);
27
- /**
28
- * The column index of the last partially visible column in the viewport.
29
- *
30
- * @type {number|null}
31
- */
32
- _defineProperty(this, "endColumn", null);
33
- /**
34
- * Position of the first partially visible column (in px).
35
- *
36
- * @type {number|null}
37
- */
38
- _defineProperty(this, "startPosition", null);
39
- /**
40
- * Determines if the viewport is visible in the trimming container.
41
- *
42
- * @type {boolean}
43
- */
44
- _defineProperty(this, "isVisibleInTrimmingContainer", false);
45
- }
46
- /**
47
- * Initializes the calculation.
48
- */
49
- initialize() {}
50
-
51
- /**
52
- * Processes the column.
53
- *
54
- * @param {number} column The column index.
55
- * @param {ViewportColumnsCalculator} viewportCalculator The viewport calculator object.
56
- */
57
- process(column, viewportCalculator) {
58
- const {
59
- totalCalculatedWidth,
60
- zeroBasedScrollOffset,
61
- viewportWidth
62
- } = viewportCalculator;
63
- if (totalCalculatedWidth <= zeroBasedScrollOffset) {
64
- this.startColumn = column;
65
- }
66
- const compensatedViewportWidth = zeroBasedScrollOffset > 0 ? viewportWidth + 1 : viewportWidth;
67
- if (totalCalculatedWidth >= zeroBasedScrollOffset && totalCalculatedWidth <= zeroBasedScrollOffset + compensatedViewportWidth) {
68
- if (this.startColumn === null || this.startColumn === undefined) {
69
- this.startColumn = column;
70
- }
71
- }
72
- this.endColumn = column;
73
- }
74
-
75
- /**
76
- * Finalizes the calculation.
77
- *
78
- * @param {ViewportColumnsCalculator} viewportCalculator The viewport calculator object.
79
- */
80
- finalize(viewportCalculator) {
81
- var _startPositions$this$;
82
- const {
83
- scrollOffset,
84
- viewportWidth,
85
- inlineStartOffset,
86
- zeroBasedScrollOffset,
87
- totalColumns,
88
- needReverse,
89
- startPositions,
90
- columnWidth
91
- } = viewportCalculator;
92
-
93
- // If the estimation has reached the last column and there is still some space available in the viewport,
94
- // we need to render in reverse in order to fill the whole viewport with columns
95
- if (this.endColumn === totalColumns - 1 && needReverse) {
96
- this.startColumn = this.endColumn;
97
- while (this.startColumn > 0) {
98
- const calculatedViewportWidth = startPositions[this.endColumn] + columnWidth - startPositions[this.startColumn - 1];
99
- this.startColumn -= 1;
100
- if (calculatedViewportWidth > viewportWidth) {
101
- break;
102
- }
103
- }
104
- }
105
- this.startPosition = (_startPositions$this$ = startPositions[this.startColumn]) !== null && _startPositions$this$ !== void 0 ? _startPositions$this$ : null;
106
- const compensatedViewportWidth = zeroBasedScrollOffset > 0 ? viewportWidth + 1 : viewportWidth;
107
- const mostRightScrollOffset = scrollOffset + viewportWidth - compensatedViewportWidth;
108
- if (
109
- // the table is to the left of the viewport
110
- mostRightScrollOffset < -1 * inlineStartOffset || scrollOffset > startPositions.at(-1) + columnWidth ||
111
- // the table is to the right of the viewport
112
- -1 * scrollOffset - viewportWidth > 0) {
113
- this.isVisibleInTrimmingContainer = false;
114
- } else {
115
- this.isVisibleInTrimmingContainer = true;
116
- }
117
- if (totalColumns < this.endColumn) {
118
- this.endColumn = totalColumns - 1;
119
- }
120
- if (this.startColumn !== null) {
121
- this.count = this.endColumn - this.startColumn + 1;
122
- }
123
- }
124
- }
125
- exports.PartiallyVisibleColumnsCalculationType = PartiallyVisibleColumnsCalculationType;
@@ -1,121 +0,0 @@
1
- import "core-js/modules/es.error.cause.js";
2
- import "core-js/modules/es.array.at.js";
3
- import "core-js/modules/es.string.at-alternative.js";
4
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
5
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
6
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
- /**
8
- * @class PartiallyVisibleColumnsCalculationType
9
- */
10
- export class PartiallyVisibleColumnsCalculationType {
11
- constructor() {
12
- /**
13
- * Total number of partially visible columns in the viewport.
14
- *
15
- * @type {number}
16
- */
17
- _defineProperty(this, "count", 0);
18
- /**
19
- * The column index of the first partially visible column in the viewport.
20
- *
21
- * @type {number|null}
22
- */
23
- _defineProperty(this, "startColumn", null);
24
- /**
25
- * The column index of the last partially visible column in the viewport.
26
- *
27
- * @type {number|null}
28
- */
29
- _defineProperty(this, "endColumn", null);
30
- /**
31
- * Position of the first partially visible column (in px).
32
- *
33
- * @type {number|null}
34
- */
35
- _defineProperty(this, "startPosition", null);
36
- /**
37
- * Determines if the viewport is visible in the trimming container.
38
- *
39
- * @type {boolean}
40
- */
41
- _defineProperty(this, "isVisibleInTrimmingContainer", false);
42
- }
43
- /**
44
- * Initializes the calculation.
45
- */
46
- initialize() {}
47
-
48
- /**
49
- * Processes the column.
50
- *
51
- * @param {number} column The column index.
52
- * @param {ViewportColumnsCalculator} viewportCalculator The viewport calculator object.
53
- */
54
- process(column, viewportCalculator) {
55
- const {
56
- totalCalculatedWidth,
57
- zeroBasedScrollOffset,
58
- viewportWidth
59
- } = viewportCalculator;
60
- if (totalCalculatedWidth <= zeroBasedScrollOffset) {
61
- this.startColumn = column;
62
- }
63
- const compensatedViewportWidth = zeroBasedScrollOffset > 0 ? viewportWidth + 1 : viewportWidth;
64
- if (totalCalculatedWidth >= zeroBasedScrollOffset && totalCalculatedWidth <= zeroBasedScrollOffset + compensatedViewportWidth) {
65
- if (this.startColumn === null || this.startColumn === undefined) {
66
- this.startColumn = column;
67
- }
68
- }
69
- this.endColumn = column;
70
- }
71
-
72
- /**
73
- * Finalizes the calculation.
74
- *
75
- * @param {ViewportColumnsCalculator} viewportCalculator The viewport calculator object.
76
- */
77
- finalize(viewportCalculator) {
78
- var _startPositions$this$;
79
- const {
80
- scrollOffset,
81
- viewportWidth,
82
- inlineStartOffset,
83
- zeroBasedScrollOffset,
84
- totalColumns,
85
- needReverse,
86
- startPositions,
87
- columnWidth
88
- } = viewportCalculator;
89
-
90
- // If the estimation has reached the last column and there is still some space available in the viewport,
91
- // we need to render in reverse in order to fill the whole viewport with columns
92
- if (this.endColumn === totalColumns - 1 && needReverse) {
93
- this.startColumn = this.endColumn;
94
- while (this.startColumn > 0) {
95
- const calculatedViewportWidth = startPositions[this.endColumn] + columnWidth - startPositions[this.startColumn - 1];
96
- this.startColumn -= 1;
97
- if (calculatedViewportWidth > viewportWidth) {
98
- break;
99
- }
100
- }
101
- }
102
- this.startPosition = (_startPositions$this$ = startPositions[this.startColumn]) !== null && _startPositions$this$ !== void 0 ? _startPositions$this$ : null;
103
- const compensatedViewportWidth = zeroBasedScrollOffset > 0 ? viewportWidth + 1 : viewportWidth;
104
- const mostRightScrollOffset = scrollOffset + viewportWidth - compensatedViewportWidth;
105
- if (
106
- // the table is to the left of the viewport
107
- mostRightScrollOffset < -1 * inlineStartOffset || scrollOffset > startPositions.at(-1) + columnWidth ||
108
- // the table is to the right of the viewport
109
- -1 * scrollOffset - viewportWidth > 0) {
110
- this.isVisibleInTrimmingContainer = false;
111
- } else {
112
- this.isVisibleInTrimmingContainer = true;
113
- }
114
- if (totalColumns < this.endColumn) {
115
- this.endColumn = totalColumns - 1;
116
- }
117
- if (this.startColumn !== null) {
118
- this.count = this.endColumn - this.startColumn + 1;
119
- }
120
- }
121
- }