Changelog
v15.5.0 (2026-03-05)
Section titled “v15.5.0 (2026-03-05)”Features
Section titled “Features”- Cell notes CRUD via
NotesManager(workbook.notes):add,get,getByCell,update,delete
Bug fixes
Section titled “Bug fixes”AND/OR/XOR/NOTevaluation with strings and other edge-case arguments, matching Excel and Google Sheets behaviorTEXTJOINandJOINnow apply cell display formats (e.g. date formats) in Google mode
Interface changes
Section titled “Interface changes”These are technically breaking, but very minor and in very recent features, so did not demand a major-version bump.
CommentsManagernow throwsSheetNotFoundError(instead of plainError) for missing sheets, with a differently worded message.WorkSheet.notestype changed toNote[](no longer possibly undefined)
Dependencies
Section titled “Dependencies”- Update
@grid-is/jsf2xlsxto ^1.3.2, updating default column width and fixing extraneousactiveTab="0"attributes inworkbookViewelements.
v15.4.0 (2026-03-02)
Section titled “v15.4.0 (2026-03-02)”Features
Section titled “Features”- Respect ‘autoNoTables’ from XLSX file, plus
deferDataTablesoption for manual control- And more generally, mark any formula cells to be deferred in recalculation
- Threaded comments CRUD via
CommentsManager(workbook.comments)
Bug fixes
Section titled “Bug fixes”MATCHreturned#N/Ainstead of#REF!in Excel missing-sheet edge casetoJsfexport expanded external workbooks to nonexistent cells if referenced in ranges- Error-like strings (e.g.
#REF!) not treated as error values when loading styled cells from CSF - Default (named) styles were not preserved in
toJsfexport
Performance
Section titled “Performance”- Much faster worst-case
describeWorkbook(label-detection) performance
Documentation
Section titled “Documentation”- Update quickstart to use
Model.fromXlsxFileinstead of manualxlsx-convert
v15.3.1 (2026-02-23)
Section titled “v15.3.1 (2026-02-23)”Bug fixes
Section titled “Bug fixes”- Preserve formula type (array or not) when result is 1x1, and classify correctly on edit
- Serialization did not preserve views, annotations, rows, and externals
- Remove Node.js util imports so consumers need not polyfill for browser compatibility
Documentation
Section titled “Documentation”- Add changelog to public docs
v15.3.0 (2026-02-19)
Section titled “v15.3.0 (2026-02-19)”Features
Section titled “Features”- Excel data tables
- Function
SORTN getViewsmethod inWorkSheetandWorkbook- Google Sheets
FLATTENfunction - Merge/unmerge cells
Bug fixes
Section titled “Bug fixes”- Make
HYPERLINK()-derived hyperlinks ephemeral - Preserve external workbooks in JSF roundtrip
- Update comment and note cell refs on move, insert, and delete
- Wrap
fs/promisesimports in try-catch to avoid bundler errors
Performance
Section titled “Performance”- Speed up
describeWorkbookby pre-filteringparseDatecalls
Documentation
Section titled “Documentation”- Pare down public API, marking stuff
@deprecatedand/or@internal - Use code blocks in Typedoc-generated docs
v15.2.0 (2026-02-10)
Section titled “v15.2.0 (2026-02-10)”Features
Section titled “Features”- Support JSF cell notes and threaded comments
Bug fixes
Section titled “Bug fixes”describeWorkbookcrash on cross-workbook ref to formula cell- Support
QUERYwithCOUNT(DISTINCT value)
v15.1.1 (2026-02-10)
Section titled “v15.1.1 (2026-02-10)”Bug fixes
Section titled “Bug fixes”- Missed dynamic dependencies in lambda-calling functions at init time
- Preserve cells with explicit empty styles through round-trip
- Strip
numberFormatFromFormulafrom exported styles intoJSF
v15.1.0 (2026-02-04)
Section titled “v15.1.0 (2026-02-04)”Features
Section titled “Features”toJsftoXlsx- Add
fromXlsxmethods for direct XLSX loading - Native
QUERYwithoutpg-mem(calling it “feat” because it supports a lot that the old one did not) - Output style indexes on rows and columns
Bug fixes
Section titled “Bug fixes”- Real workbooks override external workbooks with same name
- Fix invariant error on insert after row is deleted
- Export
ftproperty intoCSFfor array formulas - Init recalc was skipped if
!recalcVolatiles && !recalcErrors - Load XLSX files in Excel mode by default
- Respect
recalcVolatilesoption during initial recalculation - Preserve text strings that look like errors in JSF loading
ERROR.TYPEdid not support modern error codesdescribeWorkbookthrows on JSF workbook with externals- Upgrade
xlsx-convertto 3.6.4 for bugfixes - Fix
handlerRelsto work with absolute paths - Fix external refs order
- The
rproperty on cells is optional
Breaking changes
Section titled “Breaking changes”- Remove
Flagsmodule andflagsexport
v15.0.0 (2026-01-14)
Section titled “v15.0.0 (2026-01-14)”Features
Section titled “Features”- Public
Model.attachWorkbook, and documentaddWorkbookas just a wrapper - Export
StyleManager - Export
CellDatatype - Add support for JSF workbook/worksheet view props
- Specific
Errorsubclass for invalid reference strings - Add missing detail messages on
#CALC!errors
Bug fixes
Section titled “Bug fixes”- Google-mode early-date date function discrepancies
Matrix.expandmakes fully-populated matrices, causing performance disasters- Nonresolving name in
LOOKUPvector arg borks reference analysis - Propagate
markDirtyto all dependents of spill ranges - Blank spill anchor missing in
Cells.getCells - Don’t propagate recalc from unchanged spill matrix
numberFormatFromFormulapropagationSUMIFSetc. wrong forMatrixwith defaulted regions- Incorrect swap in Brent root-finding setup
QUERYwithnow()not treated as volatile if no dependencies- GSDV blocker in extended range should not block other columns
- Evaluate array expressions with mismatched row widths as
#VALUE! - Fix default column-width units discrepancy
- Fix
Tableserialization property name mismatch - Fix serialization invariant violation
- Fix errors in
toCSFexport structures - Fix GSDV spill range inference: use offset not absolute row
- Fix regression in
evaluateExpression - Preserve CSF style array when loading workbooks
Performance
Section titled “Performance”- Add
vertexIdtoCellandDefinedName - Non-volatile
OFFSETandINDIRECTandANCHORARRAYwith dynamic dependencies
Breaking changes
Section titled “Breaking changes”- CSF type should have
filename, notname - Change
NameReference.widthand.heightto beundefined, not throw
Dependencies
Section titled “Dependencies”- Update
fxto 5.0 - Upgrade Waspiary to 1.10.0 to permit
RandCnames
v15.0.0-rc3 (2026-01-08)
Section titled “v15.0.0-rc3 (2026-01-08)”Features
Section titled “Features”- Add missing detail messages on
#CALC!errors - Export
CellDatatype - Specific
Errorsubclass for invalid reference strings - Add support for JSF workbook/worksheet view props
- Preserve CSF style array when loading workbooks
Bug fixes
Section titled “Bug fixes”- GSDV blocker in extended range should not block other columns
numberFormatFromFormulapropagationSUMIFSetc. wrong forMatrixwith defaulted regions- Incorrect swap in Brent root-finding setup
QUERYwithnow()not treated as volatile if no dependencies- Evaluate array expressions with mismatched row widths as
#VALUE! - Fix GSDV spill range inference: use offset not absolute row
- Fix
Tableserialization property name mismatch - Fix serialization invariant violation
- Fix errors in
toCSFexport structures
v15.0.0-rc2 (2025-12-10)
Section titled “v15.0.0-rc2 (2025-12-10)”Bug fixes
Section titled “Bug fixes”- Blank spill anchor missing in
Cells.getCells - Don’t propagate recalc from unchanged spill matrix
- Fix regression in
evaluateExpression - CSF type should have
filename, notname
Performance
Section titled “Performance”- Non-volatile
OFFSETandINDIRECTandANCHORARRAYwith dynamic dependencies
v15.0.0-rc1 (2025-12-08)
Section titled “v15.0.0-rc1 (2025-12-08)”Features
Section titled “Features”- Public
Model.attachWorkbook, and documentaddWorkbookas just a wrapper - Export
StyleManager
Bug fixes
Section titled “Bug fixes”- Google-mode early-date date function discrepancies
Matrix.expandmakes fully-populated matrices, causing performance disasters- Non-resolving name in
LOOKUPvector arg borks reference analysis - Propagate
markDirtyto all dependents of spill ranges - Fix default column-width units discrepancy
Performance
Section titled “Performance”- Add
vertexIdtoCellandDefinedName
Breaking changes
Section titled “Breaking changes”- Change
NameReference.widthand.heightto beundefined, not throw
Dependencies
Section titled “Dependencies”- Update
fxto 5.0
v14.13.0 (2025-11-19)
Section titled “v14.13.0 (2025-11-19)”Features
Section titled “Features”- Read JSF directly
Bug fixes
Section titled “Bug fixes”- Bugs in row and column deletion and moves
- Support R1C1 syntax in
INDIRECT - Handle changed serialization
- Replace
ERROR_SPILL'foo'placeholder with proper detail message - Serialize model with lambdas in arrays
VLOOKUP/HLOOKUPcan return non-up-to-date value- Direct call to
UPLUSfails with internal error - Recalculate affected formulas if
clearGsdvclears cells
Breaking changes
Section titled “Breaking changes”- Remove
resetvalue fromDefinedNameandCellInterface
Dependencies
Section titled “Dependencies”- Switch to
@jsfkit/typesfor JSF type definitions
- Install from, and publish to, npmjs.com registry
v14.12.0 (2025-10-17)
Section titled “v14.12.0 (2025-10-17)”Breaking changes
Section titled “Breaking changes”- Make
FormulaErrorandReferencefully immutable
Features
Section titled “Features”- Store origin cell in
FormulaError - Add and improve error-value detail messages
- Add detail messages to
#SPILL!errors
Bug fixes
Section titled “Bug fixes”- Make
Cell.isBlank()closer to what its name implies - Minor bugs in reference intersection and add a test
- Rename and deprecate
Cellmethods
Documentation
Section titled “Documentation”- Deploy public API docs to GitHub Pages site
- Remove internal stuff from docs
- Mention case-insensitivity in name parameters
v14.11.0 (2025-10-15)
Section titled “v14.11.0 (2025-10-15)”Features
Section titled “Features”- Recalculate error-valued cells at init time
- Remove defined name
Bug fixes
Section titled “Bug fixes”- Wrong spill-operator result for blocked spill
QUERYcoerces dates to string by local timezone- Support structured references in
INDIRECT IFresult should not be marked dynamic- Make apiary bin work again
v14.10.1 (2025-10-01)
Section titled “v14.10.1 (2025-10-01)”Features
Section titled “Features”- Allow disabling common-subexpression extraction
Bug fixes
Section titled “Bug fixes”- Fix 1904 epoch bug when converting JSF to CSF
v14.10.0 (2025-09-25)
Section titled “v14.10.0 (2025-09-25)”Features
Section titled “Features”- Export
FormulaSyntaxErrorandEvaluationError - Add
Model.empty()convenience method - Export recalculation option symbols
Bug fixes
Section titled “Bug fixes”ADDRESSwith invalid coordinates yields wrong results or throws exception- Use source number format in
TO_TEXT - Set number format in
TO_*functions XLOOKUPthird argument wrongly forced up-to-dateROWetc. fail to update when name ref updates- False-pos circdep in
SUMIF/AVERAGEIFon target range extension Workbook.iterFormulaCellshad a bug and a redundant sibling- Update JSF support
Documentation
Section titled “Documentation”- Add a quick start guide
- Add Starlight-based documentation system
- Add tutorial for creating a spreadsheet from scratch
- Document some methods on the
Modelclass
v14.9.5 (2025-09-01)
Section titled “v14.9.5 (2025-09-01)”Features
Section titled “Features”- Add support for loading and converting JSF format
v14.9.3 (2025-08-12)
Section titled “v14.9.3 (2025-08-12)”Bug fixes
Section titled “Bug fixes”CONVERTfailed to handle reference value argument
Dependencies
Section titled “Dependencies”- Bump
fxfrom 4.11.2 to 4.12.0 [bot] - Bump
msgpackrfrom 1.11.4 to 1.11.5 [bot]
v14.9.2 (2025-07-23)
Section titled “v14.9.2 (2025-07-23)”Bug fixes
Section titled “Bug fixes”- Fix defined names causing slow iterative calculation
v14.9.1 (2025-07-22)
Section titled “v14.9.1 (2025-07-22)”Version revoked due to incorrect fix.
v14.9.0 (2025-06-27)
Section titled “v14.9.0 (2025-06-27)”- Detect parent labels
v14.8.7 (2025-06-26)
Section titled “v14.8.7 (2025-06-26)”Bug fixes
Section titled “Bug fixes”- Label sequence confusion from sparse values at island top/left
Dependencies
Section titled “Dependencies”- Bump
component-emitterfrom 1.3.0 to 2.0.0 - Upgrade
pg-memto 2.6.15
v14.8.6 (2025-06-12)
Section titled “v14.8.6 (2025-06-12)”Bug fixes
Section titled “Bug fixes”- Leftmost-column data mistaken for a label sequence
v14.8.5 (2025-06-08)
Section titled “v14.8.5 (2025-06-08)”Bug fixes
Section titled “Bug fixes”- Skip over gaps in mixed-type label subsequences
v14.8.4 (2025-06-08)
Section titled “v14.8.4 (2025-06-08)”- Improve island-based label detection