handsontable 16.1.0-next-91b8a0f-20250905 → 16.1.0-next-7cb4c1e-20250909
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/3rdparty/walkontable/src/viewport.js +30 -18
- package/3rdparty/walkontable/src/viewport.mjs +30 -18
- package/base.js +2 -2
- package/base.mjs +2 -2
- package/dist/handsontable.css +2 -2
- package/dist/handsontable.full.css +2 -2
- package/dist/handsontable.full.js +35 -23
- package/dist/handsontable.full.min.css +2 -2
- package/dist/handsontable.full.min.js +5 -5
- package/dist/handsontable.js +35 -23
- package/dist/handsontable.min.css +2 -2
- package/dist/handsontable.min.js +5 -5
- package/helpers/mixed.js +1 -1
- package/helpers/mixed.mjs +1 -1
- package/package.json +1 -1
- package/styles/handsontable.css +2 -2
- package/styles/handsontable.min.css +2 -2
- package/styles/ht-theme-classic.css +2 -2
- package/styles/ht-theme-classic.min.css +2 -2
- package/styles/ht-theme-horizon.css +2 -2
- package/styles/ht-theme-horizon.min.css +2 -2
- package/styles/ht-theme-main.css +2 -2
- package/styles/ht-theme-main.min.css +2 -2
@@ -348,12 +348,14 @@ class Viewport {
|
|
348
348
|
const rowsCalculator = this.createRowsCalculator();
|
349
349
|
const columnsCalculator = this.createColumnsCalculator();
|
350
350
|
if (fastDraw && !wtSettings.getSetting('renderAllRows')) {
|
351
|
-
const
|
352
|
-
|
351
|
+
const proposedFullyVisibleRowsCalculator = rowsCalculator.getResultsFor('fullyVisible');
|
352
|
+
const proposedPartiallyVisibleRowsCalculator = rowsCalculator.getResultsFor('partiallyVisible');
|
353
|
+
fastDraw = this.areAllProposedVisibleRowsAlreadyRendered(proposedFullyVisibleRowsCalculator, proposedPartiallyVisibleRowsCalculator);
|
353
354
|
}
|
354
355
|
if (fastDraw && !wtSettings.getSetting('renderAllColumns')) {
|
355
|
-
const
|
356
|
-
|
356
|
+
const proposedFullyVisibleColumnsCalculator = columnsCalculator.getResultsFor('fullyVisible');
|
357
|
+
const proposedPartiallyVisibleColumnsCalculator = columnsCalculator.getResultsFor('partiallyVisible');
|
358
|
+
fastDraw = this.areAllProposedVisibleColumnsAlreadyRendered(proposedFullyVisibleColumnsCalculator, proposedPartiallyVisibleColumnsCalculator);
|
357
359
|
}
|
358
360
|
if (!fastDraw) {
|
359
361
|
this.rowsRenderCalculator = rowsCalculator.getResultsFor('rendered');
|
@@ -380,30 +382,35 @@ class Viewport {
|
|
380
382
|
}
|
381
383
|
|
382
384
|
/**
|
383
|
-
* Returns information whether
|
385
|
+
* Returns information whether proposedFullyVisibleRowsCalculator viewport
|
384
386
|
* is contained inside rows rendered in previous draw (cached in rowsRenderCalculator).
|
385
387
|
*
|
386
|
-
* @param {ViewportRowsCalculator}
|
388
|
+
* @param {ViewportRowsCalculator} proposedFullyVisibleRowsCalculator The instance of the fully visible rows viewport calculator to compare with.
|
389
|
+
* @param {ViewportRowsCalculator} proposedPartiallyVisibleRowsCalculator The instance of the partially visible rows viewport calculator to compare with.
|
387
390
|
* @returns {boolean} Returns `true` if all proposed visible rows are already rendered (meaning: redraw is not needed).
|
388
391
|
* Returns `false` if at least one proposed visible row is not already rendered (meaning: redraw is needed).
|
389
392
|
*/
|
390
|
-
areAllProposedVisibleRowsAlreadyRendered(
|
393
|
+
areAllProposedVisibleRowsAlreadyRendered(proposedFullyVisibleRowsCalculator, proposedPartiallyVisibleRowsCalculator) {
|
391
394
|
if (!this.rowsVisibleCalculator) {
|
392
395
|
return false;
|
393
396
|
}
|
394
397
|
let {
|
395
398
|
startRow,
|
396
399
|
endRow
|
397
|
-
} =
|
400
|
+
} = proposedFullyVisibleRowsCalculator;
|
401
|
+
const {
|
402
|
+
startRow: partiallyVisibleStartRow,
|
403
|
+
endRow: partiallyVisibleEndRow
|
404
|
+
} = proposedPartiallyVisibleRowsCalculator;
|
398
405
|
|
399
406
|
// if there are no fully visible rows at all...
|
400
407
|
if (startRow === null && endRow === null) {
|
401
|
-
if (!
|
408
|
+
if (!proposedFullyVisibleRowsCalculator.isVisibleInTrimmingContainer && !this.wtTable.isRowBeforeRenderedRows(partiallyVisibleStartRow) && !this.wtTable.isRowAfterRenderedRows(partiallyVisibleEndRow)) {
|
402
409
|
return true;
|
403
410
|
}
|
404
411
|
// ...use partially visible rows calculator to determine what render type is needed
|
405
|
-
startRow =
|
406
|
-
endRow =
|
412
|
+
startRow = partiallyVisibleStartRow;
|
413
|
+
endRow = partiallyVisibleEndRow;
|
407
414
|
}
|
408
415
|
const {
|
409
416
|
startRow: renderedStartRow,
|
@@ -429,30 +436,35 @@ class Viewport {
|
|
429
436
|
}
|
430
437
|
|
431
438
|
/**
|
432
|
-
* Returns information whether
|
439
|
+
* Returns information whether proposedFullyVisibleColumnsCalculator viewport
|
433
440
|
* is contained inside column rendered in previous draw (cached in columnsRenderCalculator).
|
434
441
|
*
|
435
|
-
* @param {ViewportRowsCalculator}
|
442
|
+
* @param {ViewportRowsCalculator} proposedFullyVisibleColumnsCalculator The instance of the fully visible columns viewport calculator to compare with.
|
443
|
+
* @param {ViewportRowsCalculator} proposedPartiallyVisibleColumnsCalculator The instance of the partially visible columns viewport calculator to compare with.
|
436
444
|
* @returns {boolean} Returns `true` if all proposed visible columns are already rendered (meaning: redraw is not needed).
|
437
445
|
* Returns `false` if at least one proposed visible column is not already rendered (meaning: redraw is needed).
|
438
446
|
*/
|
439
|
-
areAllProposedVisibleColumnsAlreadyRendered(
|
447
|
+
areAllProposedVisibleColumnsAlreadyRendered(proposedFullyVisibleColumnsCalculator, proposedPartiallyVisibleColumnsCalculator) {
|
440
448
|
if (!this.columnsVisibleCalculator) {
|
441
449
|
return false;
|
442
450
|
}
|
443
451
|
let {
|
444
452
|
startColumn,
|
445
453
|
endColumn
|
446
|
-
} =
|
454
|
+
} = proposedFullyVisibleColumnsCalculator;
|
455
|
+
const {
|
456
|
+
startColumn: partiallyVisibleStartColumn,
|
457
|
+
endColumn: partiallyVisibleEndColumn
|
458
|
+
} = proposedPartiallyVisibleColumnsCalculator;
|
447
459
|
|
448
460
|
// if there are no fully visible columns at all...
|
449
461
|
if (startColumn === null && endColumn === null) {
|
450
|
-
if (!
|
462
|
+
if (!proposedFullyVisibleColumnsCalculator.isVisibleInTrimmingContainer && !this.wtTable.isColumnBeforeRenderedColumns(partiallyVisibleStartColumn) && !this.wtTable.isColumnAfterRenderedColumns(partiallyVisibleEndColumn)) {
|
451
463
|
return true;
|
452
464
|
}
|
453
465
|
// ...use partially visible columns calculator to determine what render type is needed
|
454
|
-
startColumn =
|
455
|
-
endColumn =
|
466
|
+
startColumn = partiallyVisibleStartColumn;
|
467
|
+
endColumn = partiallyVisibleEndColumn;
|
456
468
|
}
|
457
469
|
const {
|
458
470
|
startColumn: renderedStartColumn,
|
@@ -345,12 +345,14 @@ class Viewport {
|
|
345
345
|
const rowsCalculator = this.createRowsCalculator();
|
346
346
|
const columnsCalculator = this.createColumnsCalculator();
|
347
347
|
if (fastDraw && !wtSettings.getSetting('renderAllRows')) {
|
348
|
-
const
|
349
|
-
|
348
|
+
const proposedFullyVisibleRowsCalculator = rowsCalculator.getResultsFor('fullyVisible');
|
349
|
+
const proposedPartiallyVisibleRowsCalculator = rowsCalculator.getResultsFor('partiallyVisible');
|
350
|
+
fastDraw = this.areAllProposedVisibleRowsAlreadyRendered(proposedFullyVisibleRowsCalculator, proposedPartiallyVisibleRowsCalculator);
|
350
351
|
}
|
351
352
|
if (fastDraw && !wtSettings.getSetting('renderAllColumns')) {
|
352
|
-
const
|
353
|
-
|
353
|
+
const proposedFullyVisibleColumnsCalculator = columnsCalculator.getResultsFor('fullyVisible');
|
354
|
+
const proposedPartiallyVisibleColumnsCalculator = columnsCalculator.getResultsFor('partiallyVisible');
|
355
|
+
fastDraw = this.areAllProposedVisibleColumnsAlreadyRendered(proposedFullyVisibleColumnsCalculator, proposedPartiallyVisibleColumnsCalculator);
|
354
356
|
}
|
355
357
|
if (!fastDraw) {
|
356
358
|
this.rowsRenderCalculator = rowsCalculator.getResultsFor('rendered');
|
@@ -377,30 +379,35 @@ class Viewport {
|
|
377
379
|
}
|
378
380
|
|
379
381
|
/**
|
380
|
-
* Returns information whether
|
382
|
+
* Returns information whether proposedFullyVisibleRowsCalculator viewport
|
381
383
|
* is contained inside rows rendered in previous draw (cached in rowsRenderCalculator).
|
382
384
|
*
|
383
|
-
* @param {ViewportRowsCalculator}
|
385
|
+
* @param {ViewportRowsCalculator} proposedFullyVisibleRowsCalculator The instance of the fully visible rows viewport calculator to compare with.
|
386
|
+
* @param {ViewportRowsCalculator} proposedPartiallyVisibleRowsCalculator The instance of the partially visible rows viewport calculator to compare with.
|
384
387
|
* @returns {boolean} Returns `true` if all proposed visible rows are already rendered (meaning: redraw is not needed).
|
385
388
|
* Returns `false` if at least one proposed visible row is not already rendered (meaning: redraw is needed).
|
386
389
|
*/
|
387
|
-
areAllProposedVisibleRowsAlreadyRendered(
|
390
|
+
areAllProposedVisibleRowsAlreadyRendered(proposedFullyVisibleRowsCalculator, proposedPartiallyVisibleRowsCalculator) {
|
388
391
|
if (!this.rowsVisibleCalculator) {
|
389
392
|
return false;
|
390
393
|
}
|
391
394
|
let {
|
392
395
|
startRow,
|
393
396
|
endRow
|
394
|
-
} =
|
397
|
+
} = proposedFullyVisibleRowsCalculator;
|
398
|
+
const {
|
399
|
+
startRow: partiallyVisibleStartRow,
|
400
|
+
endRow: partiallyVisibleEndRow
|
401
|
+
} = proposedPartiallyVisibleRowsCalculator;
|
395
402
|
|
396
403
|
// if there are no fully visible rows at all...
|
397
404
|
if (startRow === null && endRow === null) {
|
398
|
-
if (!
|
405
|
+
if (!proposedFullyVisibleRowsCalculator.isVisibleInTrimmingContainer && !this.wtTable.isRowBeforeRenderedRows(partiallyVisibleStartRow) && !this.wtTable.isRowAfterRenderedRows(partiallyVisibleEndRow)) {
|
399
406
|
return true;
|
400
407
|
}
|
401
408
|
// ...use partially visible rows calculator to determine what render type is needed
|
402
|
-
startRow =
|
403
|
-
endRow =
|
409
|
+
startRow = partiallyVisibleStartRow;
|
410
|
+
endRow = partiallyVisibleEndRow;
|
404
411
|
}
|
405
412
|
const {
|
406
413
|
startRow: renderedStartRow,
|
@@ -426,30 +433,35 @@ class Viewport {
|
|
426
433
|
}
|
427
434
|
|
428
435
|
/**
|
429
|
-
* Returns information whether
|
436
|
+
* Returns information whether proposedFullyVisibleColumnsCalculator viewport
|
430
437
|
* is contained inside column rendered in previous draw (cached in columnsRenderCalculator).
|
431
438
|
*
|
432
|
-
* @param {ViewportRowsCalculator}
|
439
|
+
* @param {ViewportRowsCalculator} proposedFullyVisibleColumnsCalculator The instance of the fully visible columns viewport calculator to compare with.
|
440
|
+
* @param {ViewportRowsCalculator} proposedPartiallyVisibleColumnsCalculator The instance of the partially visible columns viewport calculator to compare with.
|
433
441
|
* @returns {boolean} Returns `true` if all proposed visible columns are already rendered (meaning: redraw is not needed).
|
434
442
|
* Returns `false` if at least one proposed visible column is not already rendered (meaning: redraw is needed).
|
435
443
|
*/
|
436
|
-
areAllProposedVisibleColumnsAlreadyRendered(
|
444
|
+
areAllProposedVisibleColumnsAlreadyRendered(proposedFullyVisibleColumnsCalculator, proposedPartiallyVisibleColumnsCalculator) {
|
437
445
|
if (!this.columnsVisibleCalculator) {
|
438
446
|
return false;
|
439
447
|
}
|
440
448
|
let {
|
441
449
|
startColumn,
|
442
450
|
endColumn
|
443
|
-
} =
|
451
|
+
} = proposedFullyVisibleColumnsCalculator;
|
452
|
+
const {
|
453
|
+
startColumn: partiallyVisibleStartColumn,
|
454
|
+
endColumn: partiallyVisibleEndColumn
|
455
|
+
} = proposedPartiallyVisibleColumnsCalculator;
|
444
456
|
|
445
457
|
// if there are no fully visible columns at all...
|
446
458
|
if (startColumn === null && endColumn === null) {
|
447
|
-
if (!
|
459
|
+
if (!proposedFullyVisibleColumnsCalculator.isVisibleInTrimmingContainer && !this.wtTable.isColumnBeforeRenderedColumns(partiallyVisibleStartColumn) && !this.wtTable.isColumnAfterRenderedColumns(partiallyVisibleEndColumn)) {
|
448
460
|
return true;
|
449
461
|
}
|
450
462
|
// ...use partially visible columns calculator to determine what render type is needed
|
451
|
-
startColumn =
|
452
|
-
endColumn =
|
463
|
+
startColumn = partiallyVisibleStartColumn;
|
464
|
+
endColumn = partiallyVisibleEndColumn;
|
453
465
|
}
|
454
466
|
const {
|
455
467
|
startColumn: renderedStartColumn,
|
package/base.js
CHANGED
@@ -45,8 +45,8 @@ Handsontable.hooks = _hooks.Hooks.getSingleton();
|
|
45
45
|
Handsontable.CellCoords = _src.CellCoords;
|
46
46
|
Handsontable.CellRange = _src.CellRange;
|
47
47
|
Handsontable.packageName = 'handsontable';
|
48
|
-
Handsontable.buildDate = "
|
49
|
-
Handsontable.version = "16.1.0-next-
|
48
|
+
Handsontable.buildDate = "09/09/2025 09:27:27";
|
49
|
+
Handsontable.version = "16.1.0-next-7cb4c1e-20250909";
|
50
50
|
Handsontable.languages = {
|
51
51
|
dictionaryKeys: _registry.dictionaryKeys,
|
52
52
|
getLanguageDictionary: _registry.getLanguageDictionary,
|
package/base.mjs
CHANGED
@@ -35,8 +35,8 @@ Handsontable.hooks = Hooks.getSingleton();
|
|
35
35
|
Handsontable.CellCoords = CellCoords;
|
36
36
|
Handsontable.CellRange = CellRange;
|
37
37
|
Handsontable.packageName = 'handsontable';
|
38
|
-
Handsontable.buildDate = "
|
39
|
-
Handsontable.version = "16.1.0-next-
|
38
|
+
Handsontable.buildDate = "09/09/2025 09:27:33";
|
39
|
+
Handsontable.version = "16.1.0-next-7cb4c1e-20250909";
|
40
40
|
Handsontable.languages = {
|
41
41
|
dictionaryKeys,
|
42
42
|
getLanguageDictionary,
|
package/dist/handsontable.css
CHANGED
@@ -26,8 +26,8 @@
|
|
26
26
|
* INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER ARISING FROM
|
27
27
|
* USE OR INABILITY TO USE THIS SOFTWARE.
|
28
28
|
*
|
29
|
-
* Version: 16.1.0-next-
|
30
|
-
* Release date: 11/09/2025 (built at
|
29
|
+
* Version: 16.1.0-next-7cb4c1e-20250909
|
30
|
+
* Release date: 11/09/2025 (built at 09/09/2025 09:27:55)
|
31
31
|
*/
|
32
32
|
/**
|
33
33
|
* Fix for bootstrap styles
|
@@ -26,8 +26,8 @@
|
|
26
26
|
* INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER ARISING FROM
|
27
27
|
* USE OR INABILITY TO USE THIS SOFTWARE.
|
28
28
|
*
|
29
|
-
* Version: 16.1.0-next-
|
30
|
-
* Release date: 11/09/2025 (built at
|
29
|
+
* Version: 16.1.0-next-7cb4c1e-20250909
|
30
|
+
* Release date: 11/09/2025 (built at 09/09/2025 09:27:55)
|
31
31
|
*/
|
32
32
|
/**
|
33
33
|
* Fix for bootstrap styles
|
@@ -25,8 +25,8 @@
|
|
25
25
|
* INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER ARISING FROM
|
26
26
|
* USE OR INABILITY TO USE THIS SOFTWARE.
|
27
27
|
*
|
28
|
-
* Version: 16.1.0-next-
|
29
|
-
* Release date: 11/09/2025 (built at
|
28
|
+
* Version: 16.1.0-next-7cb4c1e-20250909
|
29
|
+
* Release date: 11/09/2025 (built at 09/09/2025 09:27:37)
|
30
30
|
*/
|
31
31
|
(function webpackUniversalModuleDefinition(root, factory) {
|
32
32
|
if(typeof exports === 'object' && typeof module === 'object')
|
@@ -42877,8 +42877,8 @@ Handsontable.hooks = _hooks.Hooks.getSingleton();
|
|
42877
42877
|
Handsontable.CellCoords = _src.CellCoords;
|
42878
42878
|
Handsontable.CellRange = _src.CellRange;
|
42879
42879
|
Handsontable.packageName = 'handsontable';
|
42880
|
-
Handsontable.buildDate = "
|
42881
|
-
Handsontable.version = "16.1.0-next-
|
42880
|
+
Handsontable.buildDate = "09/09/2025 09:27:37";
|
42881
|
+
Handsontable.version = "16.1.0-next-7cb4c1e-20250909";
|
42882
42882
|
Handsontable.languages = {
|
42883
42883
|
dictionaryKeys: _registry.dictionaryKeys,
|
42884
42884
|
getLanguageDictionary: _registry.getLanguageDictionary,
|
@@ -54777,7 +54777,7 @@ const domMessages = {
|
|
54777
54777
|
function _injectProductInfo(key, element) {
|
54778
54778
|
const hasValidType = !isEmpty(key);
|
54779
54779
|
const isNonCommercial = typeof key === 'string' && key.toLowerCase() === 'non-commercial-and-evaluation';
|
54780
|
-
const hotVersion = "16.1.0-next-
|
54780
|
+
const hotVersion = "16.1.0-next-7cb4c1e-20250909";
|
54781
54781
|
let keyValidityDate;
|
54782
54782
|
let consoleMessageState = 'invalid';
|
54783
54783
|
let domMessageState = 'invalid';
|
@@ -84436,12 +84436,14 @@ class Viewport {
|
|
84436
84436
|
const rowsCalculator = this.createRowsCalculator();
|
84437
84437
|
const columnsCalculator = this.createColumnsCalculator();
|
84438
84438
|
if (fastDraw && !wtSettings.getSetting('renderAllRows')) {
|
84439
|
-
const
|
84440
|
-
|
84439
|
+
const proposedFullyVisibleRowsCalculator = rowsCalculator.getResultsFor('fullyVisible');
|
84440
|
+
const proposedPartiallyVisibleRowsCalculator = rowsCalculator.getResultsFor('partiallyVisible');
|
84441
|
+
fastDraw = this.areAllProposedVisibleRowsAlreadyRendered(proposedFullyVisibleRowsCalculator, proposedPartiallyVisibleRowsCalculator);
|
84441
84442
|
}
|
84442
84443
|
if (fastDraw && !wtSettings.getSetting('renderAllColumns')) {
|
84443
|
-
const
|
84444
|
-
|
84444
|
+
const proposedFullyVisibleColumnsCalculator = columnsCalculator.getResultsFor('fullyVisible');
|
84445
|
+
const proposedPartiallyVisibleColumnsCalculator = columnsCalculator.getResultsFor('partiallyVisible');
|
84446
|
+
fastDraw = this.areAllProposedVisibleColumnsAlreadyRendered(proposedFullyVisibleColumnsCalculator, proposedPartiallyVisibleColumnsCalculator);
|
84445
84447
|
}
|
84446
84448
|
if (!fastDraw) {
|
84447
84449
|
this.rowsRenderCalculator = rowsCalculator.getResultsFor('rendered');
|
@@ -84468,30 +84470,35 @@ class Viewport {
|
|
84468
84470
|
}
|
84469
84471
|
|
84470
84472
|
/**
|
84471
|
-
* Returns information whether
|
84473
|
+
* Returns information whether proposedFullyVisibleRowsCalculator viewport
|
84472
84474
|
* is contained inside rows rendered in previous draw (cached in rowsRenderCalculator).
|
84473
84475
|
*
|
84474
|
-
* @param {ViewportRowsCalculator}
|
84476
|
+
* @param {ViewportRowsCalculator} proposedFullyVisibleRowsCalculator The instance of the fully visible rows viewport calculator to compare with.
|
84477
|
+
* @param {ViewportRowsCalculator} proposedPartiallyVisibleRowsCalculator The instance of the partially visible rows viewport calculator to compare with.
|
84475
84478
|
* @returns {boolean} Returns `true` if all proposed visible rows are already rendered (meaning: redraw is not needed).
|
84476
84479
|
* Returns `false` if at least one proposed visible row is not already rendered (meaning: redraw is needed).
|
84477
84480
|
*/
|
84478
|
-
areAllProposedVisibleRowsAlreadyRendered(
|
84481
|
+
areAllProposedVisibleRowsAlreadyRendered(proposedFullyVisibleRowsCalculator, proposedPartiallyVisibleRowsCalculator) {
|
84479
84482
|
if (!this.rowsVisibleCalculator) {
|
84480
84483
|
return false;
|
84481
84484
|
}
|
84482
84485
|
let {
|
84483
84486
|
startRow,
|
84484
84487
|
endRow
|
84485
|
-
} =
|
84488
|
+
} = proposedFullyVisibleRowsCalculator;
|
84489
|
+
const {
|
84490
|
+
startRow: partiallyVisibleStartRow,
|
84491
|
+
endRow: partiallyVisibleEndRow
|
84492
|
+
} = proposedPartiallyVisibleRowsCalculator;
|
84486
84493
|
|
84487
84494
|
// if there are no fully visible rows at all...
|
84488
84495
|
if (startRow === null && endRow === null) {
|
84489
|
-
if (!
|
84496
|
+
if (!proposedFullyVisibleRowsCalculator.isVisibleInTrimmingContainer && !this.wtTable.isRowBeforeRenderedRows(partiallyVisibleStartRow) && !this.wtTable.isRowAfterRenderedRows(partiallyVisibleEndRow)) {
|
84490
84497
|
return true;
|
84491
84498
|
}
|
84492
84499
|
// ...use partially visible rows calculator to determine what render type is needed
|
84493
|
-
startRow =
|
84494
|
-
endRow =
|
84500
|
+
startRow = partiallyVisibleStartRow;
|
84501
|
+
endRow = partiallyVisibleEndRow;
|
84495
84502
|
}
|
84496
84503
|
const {
|
84497
84504
|
startRow: renderedStartRow,
|
@@ -84517,30 +84524,35 @@ class Viewport {
|
|
84517
84524
|
}
|
84518
84525
|
|
84519
84526
|
/**
|
84520
|
-
* Returns information whether
|
84527
|
+
* Returns information whether proposedFullyVisibleColumnsCalculator viewport
|
84521
84528
|
* is contained inside column rendered in previous draw (cached in columnsRenderCalculator).
|
84522
84529
|
*
|
84523
|
-
* @param {ViewportRowsCalculator}
|
84530
|
+
* @param {ViewportRowsCalculator} proposedFullyVisibleColumnsCalculator The instance of the fully visible columns viewport calculator to compare with.
|
84531
|
+
* @param {ViewportRowsCalculator} proposedPartiallyVisibleColumnsCalculator The instance of the partially visible columns viewport calculator to compare with.
|
84524
84532
|
* @returns {boolean} Returns `true` if all proposed visible columns are already rendered (meaning: redraw is not needed).
|
84525
84533
|
* Returns `false` if at least one proposed visible column is not already rendered (meaning: redraw is needed).
|
84526
84534
|
*/
|
84527
|
-
areAllProposedVisibleColumnsAlreadyRendered(
|
84535
|
+
areAllProposedVisibleColumnsAlreadyRendered(proposedFullyVisibleColumnsCalculator, proposedPartiallyVisibleColumnsCalculator) {
|
84528
84536
|
if (!this.columnsVisibleCalculator) {
|
84529
84537
|
return false;
|
84530
84538
|
}
|
84531
84539
|
let {
|
84532
84540
|
startColumn,
|
84533
84541
|
endColumn
|
84534
|
-
} =
|
84542
|
+
} = proposedFullyVisibleColumnsCalculator;
|
84543
|
+
const {
|
84544
|
+
startColumn: partiallyVisibleStartColumn,
|
84545
|
+
endColumn: partiallyVisibleEndColumn
|
84546
|
+
} = proposedPartiallyVisibleColumnsCalculator;
|
84535
84547
|
|
84536
84548
|
// if there are no fully visible columns at all...
|
84537
84549
|
if (startColumn === null && endColumn === null) {
|
84538
|
-
if (!
|
84550
|
+
if (!proposedFullyVisibleColumnsCalculator.isVisibleInTrimmingContainer && !this.wtTable.isColumnBeforeRenderedColumns(partiallyVisibleStartColumn) && !this.wtTable.isColumnAfterRenderedColumns(partiallyVisibleEndColumn)) {
|
84539
84551
|
return true;
|
84540
84552
|
}
|
84541
84553
|
// ...use partially visible columns calculator to determine what render type is needed
|
84542
|
-
startColumn =
|
84543
|
-
endColumn =
|
84554
|
+
startColumn = partiallyVisibleStartColumn;
|
84555
|
+
endColumn = partiallyVisibleEndColumn;
|
84544
84556
|
}
|
84545
84557
|
const {
|
84546
84558
|
startColumn: renderedStartColumn,
|
@@ -26,8 +26,8 @@
|
|
26
26
|
* INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER ARISING FROM
|
27
27
|
* USE OR INABILITY TO USE THIS SOFTWARE.
|
28
28
|
*
|
29
|
-
* Version: 16.1.0-next-
|
30
|
-
* Release date: 11/09/2025 (built at
|
29
|
+
* Version: 16.1.0-next-7cb4c1e-20250909
|
30
|
+
* Release date: 11/09/2025 (built at 09/09/2025 09:28:32)
|
31
31
|
*/.handsontable .table td,.handsontable .table th{border-top:none}.handsontable tr{background:#fff}.handsontable td{background-color:inherit}.handsontable .table caption+thead tr:first-child td,.handsontable .table caption+thead tr:first-child th,.handsontable .table colgroup+thead tr:first-child td,.handsontable .table colgroup+thead tr:first-child th,.handsontable .table thead:first-child tr:first-child td,.handsontable .table thead:first-child tr:first-child th{border-top:1px solid #ccc}.handsontable .table-bordered{border:0;border-collapse:separate}.handsontable .table-bordered td,.handsontable .table-bordered th{border-left:none}.handsontable .table-bordered td:first-child,.handsontable .table-bordered th:first-child{border-left:1px solid #ccc}.handsontable .table>tbody>tr>td,.handsontable .table>tbody>tr>th,.handsontable .table>tfoot>tr>td,.handsontable .table>tfoot>tr>th,.handsontable .table>thead>tr>td,.handsontable .table>thead>tr>th{line-height:21px;padding:0}.col-lg-1.handsontable,.col-lg-10.handsontable,.col-lg-11.handsontable,.col-lg-12.handsontable,.col-lg-2.handsontable,.col-lg-3.handsontable,.col-lg-4.handsontable,.col-lg-5.handsontable,.col-lg-6.handsontable,.col-lg-7.handsontable,.col-lg-8.handsontable,.col-lg-9.handsontable,.col-md-1.handsontable,.col-md-10.handsontable,.col-md-11.handsontable,.col-md-12.handsontable,.col-md-2.handsontable,.col-md-3.handsontable,.col-md-4.handsontable,.col-md-5.handsontable,.col-md-6.handsontable,.col-md-7.handsontable,.col-md-8.handsontable,.col-md-9.handsontable .col-sm-1.handsontable,.col-sm-10.handsontable,.col-sm-11.handsontable,.col-sm-12.handsontable,.col-sm-2.handsontable,.col-sm-3.handsontable,.col-sm-4.handsontable,.col-sm-5.handsontable,.col-sm-6.handsontable,.col-sm-7.handsontable,.col-sm-8.handsontable,.col-sm-9.handsontable .col-xs-1.handsontable,.col-xs-10.handsontable,.col-xs-11.handsontable,.col-xs-12.handsontable,.col-xs-2.handsontable,.col-xs-3.handsontable,.col-xs-4.handsontable,.col-xs-5.handsontable,.col-xs-6.handsontable,.col-xs-7.handsontable,.col-xs-8.handsontable,.col-xs-9.handsontable{padding-left:0;padding-right:0}.handsontable .table-striped>tbody>tr:nth-of-type(2n){background-color:#fff}.handsontable .hide{display:none}.handsontable .relative{position:relative}.handsontable .wtHider{position:relative;width:0}.handsontable .wtSpreader{height:auto;position:relative;width:0}.handsontable div,.handsontable input,.handsontable table,.handsontable tbody,.handsontable td,.handsontable textarea,.handsontable th,.handsontable thead{box-sizing:content-box;-webkit-box-sizing:content-box;-moz-box-sizing:content-box}.handsontable input,.handsontable textarea{min-height:auto}.handsontable table.htCore{border-collapse:separate;border-spacing:0;border-width:0;cursor:default;margin:0;max-height:none;max-width:none;outline-width:0;table-layout:fixed;width:0}.handsontable col,.handsontable col.rowHeader{width:50px}.handsontable td,.handsontable th{background-color:#fff;border-bottom:1px solid #ccc;border-left-width:0;border-right:1px solid #ccc;border-top-width:0;empty-cells:show;height:22px;line-height:21px;outline:none;outline-width:0;overflow:hidden;padding:0 4px;vertical-align:top;white-space:pre-wrap}[dir=rtl].handsontable td,[dir=rtl].handsontable th{border-left:1px solid #ccc;border-right-width:0}.handsontable th:last-child{border-bottom:1px solid #ccc;border-left:none;border-right:1px solid #ccc}[dir=rtl].handsontable th:last-child{border-left:1px solid #ccc;border-right:none}.handsontable .ht_clone_bottom_inline_start_corner td:first-of-type,.handsontable .ht_clone_inline_start td:first-of-type,.handsontable .ht_clone_top_inline_start_corner td:first-of-type,.handsontable th:first-child,.handsontable.ht-wrapper:not(.htFirstDatasetColumnNotRendered) td:first-of-type{border-left:1px solid #ccc}[dir=rtl].handsontable th:first-child,[dir=rtl].handsontable.ht-wrapper:not(.htFirstDatasetColumnNotRendered) td:first-of-type{border-right:1px solid #ccc}.handsontable .ht_clone_top th:nth-child(2){border-left-width:0;border-right:1px solid #ccc}[dir=rtl].handsontable .ht_clone_top th:nth-child(2){border-left:1px solid #ccc;border-right-width:0}.handsontable.htRowHeaders thead tr th:nth-child(2){border-left:1px solid #ccc}[dir=rtl].handsontable.htRowHeaders thead tr th:nth-child(2){border-right:1px solid #ccc}.handsontable tr:first-child td,.handsontable tr:first-child th{border-top:1px solid #ccc}.ht_master:not(.innerBorderInlineStart):not(.emptyColumns) tbody tr th,.ht_master:not(.innerBorderInlineStart):not(.emptyColumns) thead tr th:first-child,.ht_master:not(.innerBorderInlineStart):not(.emptyColumns)~.handsontable:not(.htGhostTable) tbody tr th,.ht_master:not(.innerBorderInlineStart):not(.emptyColumns)~.handsontable:not(.ht_clone_top):not(.htGhostTable) thead tr th:first-child{border-left:1px solid #ccc;border-right-width:0}[dir=rtl].ht_master:not(.innerBorderInlineStart):not(.emptyColumns) tbody tr th,[dir=rtl].ht_master:not(.innerBorderInlineStart):not(.emptyColumns) thead tr th:first-child,[dir=rtl].ht_master:not(.innerBorderInlineStart):not(.emptyColumns)~.handsontable:not(.htGhostTable) tbody tr th,[dir=rtl].ht_master:not(.innerBorderInlineStart):not(.emptyColumns)~.handsontable:not(.ht_clone_top):not(.htGhostTable) thead tr th:first-child{border-left-width:0;border-right:1px solid #ccc}.ht_master:not(.innerBorderTop):not(.innerBorderBottom) thead tr.lastChild th,.ht_master:not(.innerBorderTop):not(.innerBorderBottom) thead tr:last-child th,.ht_master:not(.innerBorderTop):not(.innerBorderBottom)~.handsontable thead tr.lastChild th,.ht_master:not(.innerBorderTop):not(.innerBorderBottom)~.handsontable thead tr:last-child th{border-bottom-width:0}.handsontable th{background-color:#f0f0f0;color:#222;font-weight:400;text-align:center;white-space:nowrap}.handsontable thead th{padding:0}.handsontable th.active{background-color:#ccc}.handsontable thead th .relative{padding:2px 4px}.handsontable span.colHeader{display:inline-block;line-height:1.1}.handsontable .wtBorder{font-size:0;position:absolute}.handsontable .wtBorder.hidden{display:none!important}.handsontable .wtBorder:first-child,.handsontable .wtBorder:nth-child(3){z-index:2}.handsontable .wtBorder:nth-child(2),.handsontable .wtBorder:nth-child(4){z-index:1}.handsontable .wtBorder.current{z-index:10}.handsontable .wtBorder.area{z-index:8}.handsontable .wtBorder.fill{z-index:6}.handsontable .wtBorder.corner{cursor:crosshair;font-size:0}.ht_clone_master{z-index:100}.ht_clone_inline_start{z-index:120}.ht_clone_bottom{z-index:130}.ht_clone_bottom_inline_start_corner{z-index:150}.ht_clone_top{z-index:160}.ht_clone_top_inline_start_corner{z-index:180}.handsontable col.hidden{width:0!important}.handsontable tr.hidden,.handsontable tr.hidden td,.handsontable tr.hidden th{display:none}.ht_clone_bottom,.ht_clone_inline_start,.ht_clone_top,.ht_master{overflow:hidden}.ht_master .wtHolder{overflow:auto}.handsontable .ht_clone_inline_start table.htCore>thead,.handsontable .ht_master table.htCore>tbody>tr>th,.handsontable .ht_master table.htCore>thead{visibility:hidden}.ht_clone_bottom .wtHolder,.ht_clone_inline_start .wtHolder,.ht_clone_top .wtHolder{overflow:hidden}.handsontable{color:#373737;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Helvetica Neue,Arial,sans-serif;font-size:13px;font-weight:400;position:relative;touch-action:manipulation}.handsontable a{color:#104acc}.handsontable.htAutoSize{left:-99000px;position:absolute;top:-99000px;visibility:hidden}.handsontable td.htInvalid{background-color:#ffbeba!important}.handsontable td.htNoWrap{white-space:nowrap}.handsontable td.invisibleSelection,.handsontable th.invisibleSelection{outline:none}.handsontable td.invisibleSelection::selection,.handsontable th.invisibleSelection::selection{background:hsla(0,0%,100%,0)}.hot-display-license-info{color:#373737;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Helvetica Neue,Arial,sans-serif;font-size:10px;font-weight:400;padding:5px 0 3px;text-align:left}.hot-display-license-info a{color:#104acc;font-size:10px}.ht-root-wrapper .htFocusCatcher{border:0;height:0;margin:0;opacity:0;padding:0;position:absolute;width:0;z-index:-1}.handsontable .htTextEllipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.handsontable .manualColumnResizer{cursor:col-resize;height:25px;position:absolute;top:0;width:5px;z-index:210}.handsontable .manualRowResizer{cursor:row-resize;height:5px;left:0;position:absolute;width:50px;z-index:210}.handsontable .manualColumnResizer.active,.handsontable .manualColumnResizer:hover,.handsontable .manualRowResizer.active,.handsontable .manualRowResizer:hover{background-color:#34a9db}.handsontable .manualColumnResizerGuide{background-color:#34a9db;border-left:none;border-right:1px dashed #777;display:none;margin-left:5px;margin-right:unset;position:absolute;right:unset;top:0;width:0}[dir=rtl].handsontable .manualColumnResizerGuide{border-left:1px dashed #777;border-right:none;left:unset;margin-left:unset;margin-right:5px}.handsontable .manualRowResizerGuide{background-color:#34a9db;border-bottom:1px dashed #777;bottom:0;display:none;height:0;left:0;margin-top:5px;position:absolute}.handsontable .manualColumnResizerGuide.active,.handsontable .manualRowResizerGuide.active{display:block;z-index:209}.handsontable td.area,.handsontable td.area-1,.handsontable td.area-2,.handsontable td.area-3,.handsontable td.area-4,.handsontable td.area-5,.handsontable td.area-6,.handsontable td.area-7{position:relative}.handsontable td.area-1:before,.handsontable td.area-2:before,.handsontable td.area-3:before,.handsontable td.area-4:before,.handsontable td.area-5:before,.handsontable td.area-6:before,.handsontable td.area-7:before,.handsontable td.area:before{background:#005eff;bottom:0;content:"";left:0;position:absolute;right:0;top:0}.handsontable td.area:before{opacity:.1}.handsontable td.area-1:before{opacity:.2}.handsontable td.area-2:before{opacity:.27}.handsontable td.area-3:before{opacity:.35}.handsontable td.area-4:before{opacity:.41}.handsontable td.area-5:before{opacity:.47}.handsontable td.area-6:before{opacity:.54}.handsontable td.area-7:before{opacity:.58}.handsontable tbody th.current,.handsontable thead th.current{box-shadow:inset 0 0 0 2px #4b89ff}.handsontable tbody th.ht__highlight,.handsontable thead th.ht__highlight{background-color:#dcdcdc}.handsontable tbody th.ht__active_highlight,.handsontable thead th.ht__active_highlight{background-color:#8eb0e7;color:#000}.handsontableInput{background-color:#fff;border:none;border-radius:0;box-shadow:inset 0 0 0 2px #5292f7;box-sizing:border-box!important;color:#000;display:block;font-family:inherit;font-size:inherit;line-height:21px;margin:0;outline-width:0;padding:1px 5px 0;resize:none}.handsontableInput:focus{outline:none}.handsontableInputHolder{left:0;position:absolute;top:0}.htSelectEditor{position:absolute;select{-webkit-appearance:menulist-button!important;border:2px solid #4b89ff;box-sizing:border-box!important;height:100%;width:100%}}.htSelectEditor select:focus{outline:none}.htSelectEditor .htAutocompleteArrow{display:none}.handsontable .htDimmed{color:#777}.handsontable .htSubmenu{position:relative}.handsontable .htSubmenu :after{color:#777;content:"▶";font-size:9px;position:absolute;right:5px}[dir=rtl].handsontable .htSubmenu :after{content:""}[dir=rtl].handsontable .htSubmenu :before{color:#777;content:"◀";font-size:9px;left:5px;position:absolute}.handsontable .htLeft{text-align:left}.handsontable .htCenter{text-align:center}.handsontable .htRight{text-align:right}.handsontable .htJustify{text-align:justify}.handsontable .htTop{vertical-align:top}.handsontable .htMiddle{vertical-align:middle}.handsontable .htBottom{vertical-align:bottom}.handsontable .htPlaceholder{color:#999}.handsontable.listbox{border:1px solid #ccc;margin:0}.handsontable.listbox.autocompleteEditor,.handsontable.listbox.dropdownEditor{border-width:0}.handsontable.listbox .ht_master table{background:#fff;border-collapse:separate}.handsontable.listbox.autocompleteEditor .ht_master table,.handsontable.listbox.dropdownEditor .ht_master table{border:1px solid #ccc}.handsontable.listbox td,.handsontable.listbox th,.handsontable.listbox tr:first-child td,.handsontable.listbox tr:first-child th,.handsontable.listbox tr:last-child th{border-color:transparent!important}.handsontable.listbox td,.handsontable.listbox th{text-overflow:ellipsis;white-space:nowrap}.handsontable.listbox td.htDimmed{color:inherit;cursor:default;font-style:inherit}.handsontable.listbox .wtBorder{visibility:hidden}.handsontable.listbox tr td.current,.handsontable.listbox tr:hover td{background:#eee}.ht_editor_hidden{z-index:-1}.ht_editor_visible{z-index:200}.handsontable td.htSearchResult{background:#fcedd9;color:#583707}.handsontable.mobile,.handsontable.mobile .wtHolder{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-overflow-scrolling:touch}.handsontable.mobile .handsontableInput:focus{-webkit-appearance:none;-webkit-box-shadow:inset 0 0 0 2px #5292f7;-moz-box-shadow:inset 0 0 0 2px #5292f7;box-shadow:inset 0 0 0 2px #5292f7}.handsontable .bottomSelectionHandle,.handsontable .bottomSelectionHandle-HitArea,.handsontable .topSelectionHandle,.handsontable .topSelectionHandle-HitArea{left:-10000px;right:unset;top:-10000px;z-index:9999}[dir=rtl].handsontable .bottomSelectionHandle,[dir=rtl].handsontable .bottomSelectionHandle-HitArea,[dir=rtl].handsontable .topSelectionHandle,[dir=rtl].handsontable .topSelectionHandle-HitArea{left:unset;right:-10000px}.handsontable.hide-tween{-webkit-animation:opacity-hide .3s;animation:opacity-hide .3s;animation-fill-mode:forwards;-webkit-animation-fill-mode:forwards}.handsontable.show-tween{-webkit-animation:opacity-show .3s;animation:opacity-show .3s;animation-fill-mode:forwards;-webkit-animation-fill-mode:forwards}.handsontable .htAutocompleteArrow{color:#bbb;cursor:default;float:right;font-size:10px;text-align:center;width:16px}[dir=rtl].handsontable .htAutocompleteArrow{float:left}.handsontable td.htInvalid .htAutocompleteArrow{color:#555}.handsontable td.htInvalid .htAutocompleteArrow:hover{color:#1a1a1a}.handsontable td .htAutocompleteArrow:hover{color:#777}.handsontable td.area .htAutocompleteArrow{color:#d3d3d3}.handsontable .htCheckboxRendererInput.noValue{opacity:.5}.handsontable .htCheckboxRendererLabel{cursor:pointer;display:inline-block;font-size:inherit;vertical-align:middle}.handsontable .htCheckboxRendererLabel.fullWidth{width:100%}.handsontable .collapsibleIndicator{background:#eee;border:1px solid #a6a6a6;border-radius:10px;-webkit-box-shadow:0 0 0 6px #eee;-moz-box-shadow:0 0 0 6px #eee;box-shadow:0 0 0 3px #eee;color:#222;cursor:pointer;font-size:10px;height:10px;left:unset;line-height:8px;position:absolute;right:5px;text-align:center;top:50%;transform:translateY(-50%);width:10px}[dir=rtl].handsontable .collapsibleIndicator{left:5px;right:unset}.handsontable[dir=ltr] thead th:has(.collapsibleIndicator) div.htRight span.colHeader{margin-right:20px}.handsontable[dir=rtl] thead th:has(.collapsibleIndicator) div.htLeft span.colHeader{margin-left:20px}.handsontable .columnSorting{position:relative}.handsontable[dir=ltr] div.htRight span[class*=ascending],.handsontable[dir=ltr] div.htRight span[class*=descending]{margin-left:-10px;margin-right:10px}.handsontable[dir=rtl] div.htLeft span[class*=ascending],.handsontable[dir=rtl] div.htLeft span[class*=descending]{margin-left:10px;margin-right:-10px}.handsontable[dir=ltr] div.htRight span[class*=ascending]:only-child,.handsontable[dir=ltr] div.htRight span[class*=descending]:only-child{margin-left:-15px;margin-right:15px}.handsontable[dir=rtl] div.htLeft span[class*=ascending]:only-child,.handsontable[dir=rtl] div.htLeft span[class*=descending]:only-child{margin-left:15px;margin-right:-15px}.handsontable .columnSorting.sortAction:hover{cursor:pointer;text-decoration:underline}.handsontable span.colHeader.columnSorting:before{background-position-x:right;background-repeat:no-repeat;background-size:contain;content:"";height:10px;left:unset;margin-top:-6px;padding-left:8px;padding-right:0;position:absolute;right:-9px;top:50%;width:5px}[dir=rtl].handsontable span.colHeader.columnSorting:before{background-position-x:left;left:-9px;padding-left:0;padding-right:8px;right:unset}.handsontable span.colHeader.columnSorting.ascending:before{background-image:url()}.handsontable span.colHeader.columnSorting.descending:before{background-image:url()}.htGhostTable .htCore span.colHeader.columnSorting:not(.indicatorDisabled):before{content:"*";display:inline-block;padding-right:20px;position:relative}.handsontable.htGhostTable table thead th{border-bottom-width:0}.handsontable.htGhostTable table tbody tr td,.handsontable.htGhostTable table tbody tr th{border-top-width:0}.handsontable .htCommentCell{position:relative}.handsontable .htCommentCell:after{border-left:6px solid transparent;border-right:none;border-top:6px solid #000;content:"";left:unset;position:absolute;right:0;top:0}[dir=rtl].handsontable .htCommentCell:after{border-left:none;border-right:6px solid transparent;left:0;right:unset}.htCommentsContainer .htComments{display:none;position:absolute;z-index:1059}.htCommentsContainer .htCommentTextArea{-webkit-appearance:none;background-color:#fff;border:none;border-left:3px solid #ccc;box-shadow:0 1px 3px rgba(0,0,0,.118),0 1px 2px rgba(0,0,0,.239);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;font-size:12px;height:90px;outline:0!important;padding:5px;width:215px}[dir=rtl].htCommentsContainer .htCommentTextArea{border-left:none;border-right:3px solid #ccc}.htCommentsContainer .htCommentTextArea:focus{border-left:3px solid #5292f7;border-right:none;box-shadow:0 1px 3px rgba(0,0,0,.118),0 1px 2px rgba(0,0,0,.239),inset 0 0 0 1px #5292f7}[dir=rtl].htCommentsContainer .htCommentTextArea:focus{border-left:none;border-right:3px solid #5292f7}
|
32
32
|
/*!
|
33
33
|
* Handsontable ContextMenu
|