v0.32.1
This is an ad-hoc patch release to include #7602 - which fixes an issue that could corrupt a document if a TabNode was at the anchor or focus of a selection when text is inserted under certain circumstances.
Core
- ✅ #7602 Treat all TabNode as if they are in token mode
- ✅ #7579 Firefox now handles Select All (Ctrl+A) the same way as other browsers
- [Monthly Release] v0.32.0 by @lilshady in https://github.com/facebook/lexical/pull/7599
- [lexical][lexical-selection] Bug Fix: Treat all TabNode as if they are in token mode by @etrepum in https://github.com/facebook/lexical/pull/7602
- [scripts] update next version in lexical-esm-nextjs by @lilshady in https://github.com/facebook/lexical/pull/7604
- [tests] Chore: Update table test to use locator API instead of page.evaluate by @etrepum in https://github.com/facebook/lexical/pull/7603
- [lexical] Fix: ctrl+a doesn't work well in plain text mode on Firefox by @wataru-chocola in https://github.com/facebook/lexical/pull/7579
- @wataru-chocola made their first contribution in https://github.com/facebook/lexical/pull/7579
Full Changelog: https://github.com/facebook/lexical/compare/v0.32.0...v0.32.1
v0.32.0
Core
- ✅ #7544 2 Tabs on single line selection should indent
- 🆕 #7573 Feature: Improve Tab/Indent/Outdent to match VSCode
- ✅ #7568 unbulleting an image doesn't work #5698 ([lexical-selection][lexical-playground])
- 🆕 #7593 Type: Add flow export type for LexicalUpdateTags
Playground
- ✅ #7556 Change list, strikethrough and quoteblock shortcuts to match Google Docs for Windows compatibility
- ✅ #7545 Support Apple Pencil
- 🆕 #7567 Chore: source command priority from package
- ✅ #7572 Preserve row striping in frozen table columns
- ✅ #7568 unbulleting an image doesn't work #5698
- ✅ #7558 Made checklist icon fully scalable, clickable, and properly spaced at large font sizes
- 🆕 #7590 Refactor: simplify ExcalidrawModal
- 🆕 #7509 FloatingUI Context Menu
- 🆕 #7596 Chore: source command priority from package
Markdown
- ✅ #7560 Link Transformer URL Protocol Han…
- ✅ #7564 Prevent transform from removing nodes if the replace function returns false
- ✅ #7594 Don't select nodes when importing
React
- ✅ #7589 page freezes when typing a link in an overflow area
- 🆕 #7584 Feature: allow whitespaces in search keyword in useBasicTypeaheadTriggerMatch
Website
- ✅ #7569 fix documentation typos
- ✅ #7574 Fix docusaurus build by adding removeLegacyPostBuildHeadAttribute flag
- v0.31.2 by @etrepum in https://github.com/facebook/lexical/pull/7550
- Revert "[lexical-markdown] Bug Fix: Link Transformer URL Protocol Han… by @zurfyx in https://github.com/facebook/lexical/pull/7560
- [lexical-playground] Bug Fix: Change list, strikethrough and quoteblock shortcuts to match Google Docs for Windows compatibility by @harshmetkel24 in https://github.com/facebook/lexical/pull/7556
- [lexical-code] Bug Fix: 2 Tabs on single line selection should indent by @jeromew in https://github.com/facebook/lexical/pull/7544
- [lexical-list] Bug Fix: Removed the hardcoded checkbox width in checklist onclick helper by @jvithlani in https://github.com/facebook/lexical/pull/7559
- [lexical][lexical-playground] Bug Fix: Support Apple Pencil by @circlingthesun in https://github.com/facebook/lexical/pull/7545
- [lexical-markdown] Bug fix: Prevent transform from removing nodes if the replace function returns false by @rodrigomotion in https://github.com/facebook/lexical/pull/7564
- [lexical-website] Chore: fix documentation typos by @noritaka1166 in https://github.com/facebook/lexical/pull/7569
- [lexical-playground] Chore: source command priority from package by @eliottvincent in https://github.com/facebook/lexical/pull/7567
- [lexical-playground] Bug Fix: Preserve row striping in frozen table columns by @kirandash in https://github.com/facebook/lexical/pull/7572
- [Update] Fix docusaurus build by adding removeLegacyPostBuildHeadAttribute flag by @lilshady in https://github.com/facebook/lexical/pull/7574
- [lexical-selection][lexical-playground] Bug Fix: unbulleting an image doesn't work #5698 by @kamilpitula in https://github.com/facebook/lexical/pull/7568
- [lexical-playground][lexical-list] Bug Fix: Made checklist icon fully scalable, clickable, and properly spaced at large font sizes by @swrsaini in https://github.com/facebook/lexical/pull/7558
- [lexical-table] Bug Fix: error when deleting multiple rows with merged row cells by @kamilpitula in https://github.com/facebook/lexical/pull/7582
- [lexical-link] Feature: Move URL formatting from #7499 to LinkNode sanitizeUrl by @etrepum in https://github.com/facebook/lexical/pull/7585
- [lexical-react][lexical-playground] FloatingUI Context Menu by @ivailop7 in https://github.com/facebook/lexical/pull/7509
- [lexical-playground] Refactor: simplify ExcalidrawModal by @thorn0 in https://github.com/facebook/lexical/pull/7590
- [lexical-react] Bug Fix: page freezes when typing a link in an overflow area by @kamilpitula in https://github.com/facebook/lexical/pull/7589
- [lexical-react][lexical-playground] Feature: allow whitespaces in search keyword in useBasicTypeaheadTriggerMatch by @harshmetkel24 in https://github.com/facebook/lexical/pull/7584
- [lexical-code] Feature: Improve Tab/Indent/Outdent to match VSCode by @jeromew in https://github.com/facebook/lexical/pull/7573
- [Lexical] Type: Add flow export type for
LexicalUpdateTags
by @ttzztztz in https://github.com/facebook/lexical/pull/7593 - [lexical-playground][lexical-rich-text][lexical-website][tests][examples] Chore: source command priority from package by @eliottvincent in https://github.com/facebook/lexical/pull/7596
- [lexical-markdown] Bug Fix: Don't select nodes when importing by @juusolain in https://github.com/facebook/lexical/pull/7594
- @jeromew made their first contribution in https://github.com/facebook/lexical/pull/7544
- @circlingthesun made their first contribution in https://github.com/facebook/lexical/pull/7545
- @rodrigomotion made their first contribution in https://github.com/facebook/lexical/pull/7564
- @noritaka1166 made their first contribution in https://github.com/facebook/lexical/pull/7569
- @eliottvincent made their first contribution in https://github.com/facebook/lexical/pull/7567
- @kamilpitula made their first contribution in https://github.com/facebook/lexical/pull/7568
- @swrsaini made their first contribution in https://github.com/facebook/lexical/pull/7558
- @ttzztztz made their first contribution in https://github.com/facebook/lexical/pull/7593
- @juusolain made their first contribution in https://github.com/facebook/lexical/pull/7594
Full Changelog: https://github.com/facebook/lexical/compare/v0.31.2...v0.32.0
v0.31.2
Patch release for #7549, this is a bug fix release
Core:
- ✅ #7549 Fix infinite loop in indexPath
- ✅ #7536 Do not export empty textAlign styles
Code:
- ✅ #7538 Allow code highlighter to be used in headless mode
Markdown:
- ✅ #7539 Do not export auto-link nodes
Playground:
- ✅ #7534 Use babel MatchPatterns that work correctly on Windows
- v0.31.1 by @etrepum in https://github.com/facebook/lexical/pull/7525
- [lexical-playground] Bug Fix: Use babel MatchPatterns that work correctly on windows by @etrepum in https://github.com/facebook/lexical/pull/7534
- [lexical-website] Chore: Update docusaurus-plugin-internaldocs-fb and reorg serialization docs by @etrepum in https://github.com/facebook/lexical/pull/7533
- [lexical] Bug Fix : Prevent from adding element.style.textAlign when formatType is unset by @baptistejamin in https://github.com/facebook/lexical/pull/7536
- [lexical-code] Bug Fix: Allow Code Highlighter to be working in headless mode by @baptistejamin in https://github.com/facebook/lexical/pull/7538
- [lexical-markdown]: Bug fix: Do not export auto-link nodes by @baptistejamin in https://github.com/facebook/lexical/pull/7539
- [lexical] Bug Fix: Fix loop in indexPath by @etrepum in https://github.com/facebook/lexical/pull/7549
- @baptistejamin made their first contribution in https://github.com/facebook/lexical/pull/7536
Full Changelog: https://github.com/facebook/lexical/compare/v0.31.1...v0.31.2
v0.31.1
This is a patch release primarily to address a dev tools build regression (#7522)
Rich Text
- ✅ #7516 Backspace now only dedents at the start of first descendant of an indented block
List
- ✅ #7504 Marker styles are now inherited on indent
Markdown
- ✅ #7499 Link transformer now explicitly adds a protocol to URLs
React
- 🆕 #7520
useBasicTypeaheadTriggerMatch
punctuation regex fragment is now configurable
Table
- ✅ #7498 TableNode DOM import now supports frozen rows and columns
Playground
- ✅ #7506 LexicalTypeaheadMenuPlugin is now positioned correctly when scrolled
- ✅ #7508 Change text capitalization keyboard shortcuts on macOS to avoid conflicts
- ✅ #7520 Emoji typeahead search now permits underscore and dashes
Dev Tools
- ✅ #7522 Vite configuration fix for devtools build
Docs
- 🆕 #7294 New NodeState documentation and example
- Monthly Release: v0.31.0 by @lilshady in https://github.com/facebook/lexical/pull/7502
- [lexical-table] Bug Fix: Add missing DOM import for TableNode frozen rows and columns by @Iaotle in https://github.com/facebook/lexical/pull/7498
- [lexical-markdown] Bug Fix: Link Transformer URL Protocol Handling by @AashishRichhariya in https://github.com/facebook/lexical/pull/7499
- [lexical-list] Bug Fix: Inherit marker styles when indenting list items by @kirandash in https://github.com/facebook/lexical/pull/7504
- [lexical-playground] Bug Fix: LexicalTypeaheadMenuPlugin Positioning When Scrolled by @AashishRichhariya in https://github.com/facebook/lexical/pull/7506
- [lexical][lexical-website] Documentation: Start on NodeState docs and examples by @etrepum in https://github.com/facebook/lexical/pull/7294
- [lexical-rich-text] Bug Fix: Backspace should only dedent at first descendant of indented block by @etrepum in https://github.com/facebook/lexical/pull/7516
- [lexical-playground] Bug Fix: capitalize shortcut not working in macos fix by @harshmetkel24 in https://github.com/facebook/lexical/pull/7508
- [lexical-react][lexical-playground] Bug Fix: Make typeahead punctuation configurable; allow underscores and dashes in emoji queries by @kirandash in https://github.com/facebook/lexical/pull/7520
- [lexical-devtools] Bug Fix: Update devtools vite config for process.env.LEXICAL_VERSION by @etrepum in https://github.com/facebook/lexical/pull/7522
- @Iaotle made their first contribution in https://github.com/facebook/lexical/pull/7498
- @AashishRichhariya made their first contribution in https://github.com/facebook/lexical/pull/7499
Full Changelog: https://github.com/facebook/lexical/compare/v0.31.0...v0.31.1
v0.31.0
Core
- ✅ #7439 Correct caret movement in vertical-rl writing mode
- ✅ #7450 Migrate string literals to update tag constants
- ✅ #7471 Chore: Update sveltejs dependency
- ✅ #7479 Revert Enter command to use inexact matching
- ✅ #7481 Update KEY_ENTER_COMMAND API docs Website
- 🆕 #7442 Improve createCommand developer experience
- 🆕 #7441 Document and export common update tags
- 🆕 #7448 Documentation Update: Add detailed guides for key and clone concepts
Playground
- 🆕 #7464 Add keyboard shortcut for comments
- ✅ #7462 Stabilize text format dropdown width in toolbar
- ✅ #7478 Disable flaky "Can expand table to fit content when pasting table into table" in collab
- 🆕 #7482 Refactor autolink tests for reliability
React
- 🆕 #7477 Make check for entity boundary configurable in LexicalTypeaheadMenuPlugin
- ✅ #7488 Re-render tables when the hasHorizontalScroll setting is changed
- ✅ #7486 Support custom cursor sync in CollaborationPlugin
Collab
- 🆕 #7453 Simplify removeFromParent internal operations
Table
- ✅ #7447 Handle backspace deletion of tables with merged cells
Markdown
- ✅ #7476 Add import support for backslash escape sequences
- v0.30.0 by @etrepum in https://github.com/facebook/lexical/pull/7440
- [lexical][lexical-website] Feature: Improve createCommand developer experience by @kirandash in https://github.com/facebook/lexical/pull/7442
- [lexical][lexical-website] Feature: Document and export common update tags by @kirandash in https://github.com/facebook/lexical/pull/7441
- [lexical-selection] Bug Fix: Correct caret movement in vertical-rl writing mode by @kirandash in https://github.com/facebook/lexical/pull/7439
- [lexical-table][lexical-playground] Bug Fix: Handle backspace deletion of tables with merged cells by @kirandash in https://github.com/facebook/lexical/pull/7447
- Chore: migrate string literals to update tag constants by @kirandash in https://github.com/facebook/lexical/pull/7450
- [lexical-playground] fix: clarify EquationComponent inputRef type by @navidmafi in https://github.com/facebook/lexical/pull/7460
- [lexical] Chore: Update internalMarkNodeAsDirty TODO comment by @kirandash in https://github.com/facebook/lexical/pull/7457
- [lexical-playground] Feature: Add keyboard shortcut for comments by @kirandash in https://github.com/facebook/lexical/pull/7464
- [lexical-playground] Bug Fix: Stabilize text format dropdown width in toolbar by @kirandash in https://github.com/facebook/lexical/pull/7462
- [lexical-yjs][lexical] Refactor: Simplify removeFromParent internal operations by @kirandash in https://github.com/facebook/lexical/pull/7453
- Chore: Update sveltejs dependency by @Garvit244 in https://github.com/facebook/lexical/pull/7471
- [lexical] Bug Fix exact modifier matching for built-in keyboard shortcuts by @10tacion in https://github.com/facebook/lexical/pull/7443
- [lexical][lexical-playground] Chore: Deprecate KEY_MODIFIER_COMMAND and use KEY_DOWN_COMMAND for playground shortcuts by @etrepum in https://github.com/facebook/lexical/pull/7472
- [lexical-markdown] Bug Fix: Add import support for backslash escape sequences by @etrepum in https://github.com/facebook/lexical/pull/7476
- [lexical-playground] Chore: Disable flaky "Can expand table to fit content when pasting table into table" in collab by @etrepum in https://github.com/facebook/lexical/pull/7478
- [lexical] Chore: Revert Enter command to use inexact matching by @takuyakanbr in https://github.com/facebook/lexical/pull/7479
- [lexical] Chore: Update KEY_ENTER_COMMAND API docs by @etrepum in https://github.com/facebook/lexical/pull/7481
- [lexical-playground] Chore: Refactor autolink tests for reliability by @etrepum in https://github.com/facebook/lexical/pull/7482
- [lexical-react] Feature: make check for entity boundary configurable in LexicalTypeaheadMenuPlugin by @asevich in https://github.com/facebook/lexical/pull/7477
- [lexical-website] Documentation Update: Add detailed guides for key and clone concepts by @kirandash in https://github.com/facebook/lexical/pull/7448
- [lexical-react][lexical-table] Bug Fix: Re-render tables when the hasHorizontalScroll setting is changed by @etrepum in https://github.com/facebook/lexical/pull/7488
- [lexical-react][lexical-yjs] Feature: Support custom cursor sync in CollaborationPlugin by @simonecervini in https://github.com/facebook/lexical/pull/7486
- @navidmafi made their first contribution in https://github.com/facebook/lexical/pull/7460
- @Garvit244 made their first contribution in https://github.com/facebook/lexical/pull/7471
- @10tacion made their first contribution in https://github.com/facebook/lexical/pull/7443
- @asevich made their first contribution in https://github.com/facebook/lexical/pull/7477
- @simonecervini made their first contribution in https://github.com/facebook/lexical/pull/7486
Full Changelog: https://github.com/facebook/lexical/compare/v0.30.0...v0.31.0
v0.30.0
#7378 changed the internal updateEditorSync
implementation to always use the correct active editor when triggering a listener. This only affects how nested editors delegate their events to listeners attached to a parent editor. If you have listeners attached to the parent editor that expect to be called with the context of the nested editor then you'll have to either also attach the listener to the nested editor, or change the behavior to check the editor argument of the command listener to see which editor the command was originally dispatched to.
#7386 changed the behavior of the markdown import's paragraph merging logic to align with GitHub's markdown editor behavior for list and common markdown formatting expectations when shouldPreserveNewlines
is true.
#7400 changed the markdown encoder to replace leading or trailing whitespace of formatted strings with the corresponding HTML entities
Core
- ✅ #7378 Ensure updateEditorSync is always synchronous and use it when triggering listeners
- ✅ #7393 Fix right and up arrow key navigation with decorator nodes
- ✅ #7401 Clone the selection and use $setSelection instead of assigning dirty to true directly
- ✅ #7397 Change
$getTextNodeOffset
invariant to warn in prod (error in__DEV__
) - ✅ #7412 Fix forward line deletion when using control+K
- 🆕 #7438 Add text-transform styles to exported HTML
Rich Text
- ✅ #7411 Prevent indentation from becoming negative
Collab
- ✅ #7330 Don't sync ElementNode
__dir
property - ✅ #7398 Fix scroll position getting changed when someone else makes a change in collab
Markdown
- ✅ #7386 Preserve paragraph separation after block elements
- ✅ #7395 Prevent Markdown shortcuts from applying to code-formatted text
- ✅ #7400 Replace whitespace with code point when the string has leading and trailing whitespaces
List
- ✅ #7380 Empty list item type change
- ✅ #7420 Enforce strict list indentation
- 🆕 #7429 Export
registerCheckList
Link
- ✅ #7366 Add support for image links via NodeSelection
Devtools
- ✅ #7403 Update debug view to show KEY_ESCAPE_COMMAND immediately
React
- 🆕 #7404 Add option to disable first item auto-selection in menus
Table
- 🆕 #7408 Improve logic for pasting table into table
- 🆕 #7415 Rename and deprecate some table utils
Playground
- 🆕 #7384 Clear block ElementNode formatting along with TextNode
- 🆕 #7417 Clear formatting should also clear any indent/outdent if applied
- ✅ #7368 Remove shared imports from playground for easier re-use
- ✅ #7388 Use natural dimensions for inherited image size
- ✅ #7405 Fix floating toolbar position for end-aligned text
- ✅ #7431 Fix immediate broken image display on load failure
- v0.29.0 by @lilshady in https://github.com/facebook/lexical/pull/7375
- [tests] Update next version by @lilshady in https://github.com/facebook/lexical/pull/7374
- [lexical-playground] Chore: Remove shared imports from playground by @etrepum in https://github.com/facebook/lexical/pull/7368
- [lexical-list] Bug Fix: empty list item type change by @fantactuka in https://github.com/facebook/lexical/pull/7380
- [Breaking Change][lexical] Bug Fix: Ensure updateEditorSync is always synchronous and use it when triggering listeners by @etrepum in https://github.com/facebook/lexical/pull/7378
- Update dependencies: vite,@babel/runtime,prismjs,@babel/helpers by @lilshady in https://github.com/facebook/lexical/pull/7381
- update codeowners by @potatowagon in https://github.com/facebook/lexical/pull/7389
- [lexical-playground] Feature: clear blockelement formatting along with textNode by @harshmetkel24 in https://github.com/facebook/lexical/pull/7384
- [lexical-playground] Bug Fix: Use natural dimensions for inherited image size by @kirandash in https://github.com/facebook/lexical/pull/7388
- [Breaking Change][lexical-markdown] Bug Fix: Preserve paragraph separation after block elements by @kirandash in https://github.com/facebook/lexical/pull/7386
- [lexical-link][lexical-playground] Feature: Add support for image links via NodeSelection by @kirandash in https://github.com/facebook/lexical/pull/7366
- [lexical-yjs] Bug Fix: don't sync ElementNode __dir property by @james-atticus in https://github.com/facebook/lexical/pull/7330
- [lexical-rich-text] Bug Fix: Fix right and up arrow key navigation with decorator nodes by @kirandash in https://github.com/facebook/lexical/pull/7393
- [lexical-markdown] Bug Fix: Prevent Markdown shortcuts from applying to code-formatted text by @takuyakanbr in https://github.com/facebook/lexical/pull/7395
- [lexical-yjs] Bug Fix: Fix scroll position getting changed when someone else makes a change in collab by @amanharwara in https://github.com/facebook/lexical/pull/7398
- [RFC][lexical-markdown] Replace whitespace with code point when the string has leading and trailing whitespaces by @lilshady in https://github.com/facebook/lexical/pull/7400
- [Bug Fix] Clone a node and use
$setSelection
instead of assigning dirty to true directly. by @lilshady in https://github.com/facebook/lexical/pull/7401 - [lexical-devtools-core] Bug Fix: Update debug view to show KEY_ESCAPE_COMMAND immediately by @kirandash in https://github.com/facebook/lexical/pull/7403
- [lexical-react] Feature: Add option to disable first item auto-selection in menus by @kirandash in https://github.com/facebook/lexical/pull/7404
- [lexical] Chore: Change $getTextNodeOffset invariant to warn in prod (error in DEV) by @etrepum in https://github.com/facebook/lexical/pull/7397
- [lexical-playground] Bug Fix: Floating toolbar position for end-aligned text by @kirandash in https://github.com/facebook/lexical/pull/7405
- [lexical] Bug Fix: Fix forward line deletion when using control+K by @takuyakanbr in https://github.com/facebook/lexical/pull/7412
- [lexical-rich-text] Bug Fix: Prevent indentation from becoming negative by @takuyakanbr in https://github.com/facebook/lexical/pull/7411
- [lexical-table] Feature: Improve logic for pasting table into table by @takuyakanbr in https://github.com/facebook/lexical/pull/7408
- [lexical-table] Refactor: Rename and deprecate some table utils by @takuyakanbr in https://github.com/facebook/lexical/pull/7415
- [lexical-playground] Bug: clear formatting should also clear any indent/outdent if applied by @harshmetkel24 in https://github.com/facebook/lexical/pull/7417
- [lexical-list] Feature: Enforce strict list indentation by @dineug in https://github.com/facebook/lexical/pull/7420
- [lexical-playground] Bug Fix: Immediate broken image display on load failure by @kirandash in https://github.com/facebook/lexical/pull/7431
- Chore: Improve spelling consistency across codebase by @kirandash in https://github.com/facebook/lexical/pull/7437
- [lexical] Feature: Add text-transform styles to exported HTML by @kirandash in https://github.com/facebook/lexical/pull/7438
- [lexical-list] Feature: export registerCheckList by @atsjo in https://github.com/facebook/lexical/pull/7429
- @harshmetkel24 made their first contribution in https://github.com/facebook/lexical/pull/7384
- @takuyakanbr made their first contribution in https://github.com/facebook/lexical/pull/7395
- @atsjo made their first contribution in https://github.com/facebook/lexical/pull/7429
Full Changelog: https://github.com/facebook/lexical/compare/v0.29.0...v0.30.0
v0.29.0
https://github.com/facebook/lexical/pull/7351 : Only select RootNode on removal of last child if there was an existing selection https://github.com/facebook/lexical/pull/7353: Support escaping markdown characters https://github.com/facebook/lexical/pull/7357: Refactor: LexicalNestedComposer add skipEditableListener prop and deprecate initialNodes prop and implicit namespace setting https://github.com/facebook/lexical/pull/7372: Set tableFrozenColumn and tableFrozenRow classes only on the scrollable table wrapper
React: 🆕 https://github.com/facebook/lexical/pull/7357: LexicalNestedComposer add skipEditableListener prop and deprecate initialNodes prop and implicit namespace setting
Table: ✅https://github.com/facebook/lexical/pull/7372: Set tableFrozenColumn and tableFrozenRow classes only on the scrollable table wrapper ✅https://github.com/facebook/lexical/pull/7316: Add fallback selection to InsertTableCommand
Core editor: ✅https://github.com/facebook/lexical/pull/7351: Only select RootNode on removal of last child if there was an existing selection ✅https://github.com/facebook/lexical/pull/7354: Ignore input event from inside decorators
Markdown: 🆕 https://github.com/facebook/lexical/pull/7353: Feature: Support escaping markdown characters
Playground: 🆕 https://github.com/facebook/lexical/pull/7352 : Chore: Improve accessibility of DraggableBlockPlugin add block button ✅https://github.com/facebook/lexical/pull/7334: Table action menu visibility with cell overflow ✅https://github.com/facebook/lexical/pull/7362: Fix equation rendering in Safari 🆕 https://github.com/facebook/lexical/pull/7371: Chore: Update excalidraw to v0.18.0 Doc: ✅https://github.com/facebook/lexical/pull/7365: Update react.md, fix typo
- v0.28.0 by @etrepum in https://github.com/facebook/lexical/pull/7348
- [lexical-playground] Chore: Improve accessibility of DraggableBlockPlugin add block button by @etrepum in https://github.com/facebook/lexical/pull/7352
- [Breaking Change][lexical] Bug Fix: Only select RootNode on removal of last child if there was an existing selection by @etrepum in https://github.com/facebook/lexical/pull/7351
- [lexical-playground] Bug Fix: Table action menu visibility with cell overflow by @kirandash in https://github.com/facebook/lexical/pull/7334
- [Breaking Change][lexical-markdown] Feature: Support escaping markdown characters by @AlessioGr in https://github.com/facebook/lexical/pull/7353
- [lexical-table] Bug Fix: Add fallback selection to InsertTableCommand by @patrick-atticus in https://github.com/facebook/lexical/pull/7316
- Update react.md, fix typo by @bohdanbirdie in https://github.com/facebook/lexical/pull/7365
- [lexical-playground] Bug Fix: Fix equation rendering in Safari by @kirandash in https://github.com/facebook/lexical/pull/7362
- [Breaking Change][lexical-react] Refactor: LexicalNestedComposer add skipEditableListener prop and deprecate initialNodes prop and implicit namespace setting by @etrepum in https://github.com/facebook/lexical/pull/7357
- [lexical] Bug Fix: Ignore input event from inside decorators by @etrepum in https://github.com/facebook/lexical/pull/7354
- [Breaking Change][lexical-table][lexical-playground] Bug Fix: Set tableFrozenColumn and tableFrozenRow classes only on the scrollable table wrapper by @etrepum in https://github.com/facebook/lexical/pull/7372
- [lexical-playground] Chore: Update excalidraw to v0.18.0 by @etrepum in https://github.com/facebook/lexical/pull/7371
- @bohdanbirdie made their first contribution in https://github.com/facebook/lexical/pull/7365
Full Changelog: https://github.com/facebook/lexical/compare/v0.28.0...v0.29.0
v0.28.0
Ad-hoc minor release with important bug fixes and some enabling features. The most important fix is in #7341 - where under certain conditions nodes may not be updated in the DOM at all (this bug is rarely triggered and has been around for 3+ years).
If you have any $onDelete
handlers copied from the playground for KEY_DELETE_COMMAND
and KEY_BACKSPACE_COMMAND
, you can delete them all now. If you leave them in, it will have similar bugs as prior to this PR.
The default KEY_DELETE_COMMAND
and KEY_BACKSPACE_COMMAND
handlers now event.preventDefault()
and call DELETE_CHARACTER_COMMAND
for NodeSelection
(in addition to the existing RangeSelection
behavior).
The DELETE_CHARACTER_COMMAND
handler now handles NodeSelection by calling the new NodeSelection.deleteNodes()
method which places a new RangeSelection
where the first selected node was (if any, and if it was the current selection) and then removes all of the selected nodes.
This PR moves the incorrectly overridden append
methods for RootNode
and ListNode
and moves it to the ElementNode
's primitive splice
method. For RootNode this means that the exception you'd get for appending a leaf node to the root will be thrown in all situations when that node is inserted, rather than just append. For ListNode
this means that the automatic ListItemNode
wrapping applies in all situations when children are inserted into the node, not just append.
Previously $insertNodeToNearestRoot
could create empty ElementNode
when splitting the current node, now it respects canBeEmpty()
and will not split in those cases (e.g. ListNode
).
The approach used in #7024 (since v0.26.0) to have a ListItemNode
bullet inherit the style of the first text node was too broad, the inline style on the ListItemNode
cascades to all of its children. The only way around this is to change the approach.
To retain this feature, you need to add CSS to your theme to specifically style the marker pseudo-element based on these new custom properties. Here's an example from the playground css:
.PlaygroundEditorTheme__listItem::marker {
color: var(--listitem-marker-color);
background-color: var(--listitem-marker-background-color);
font-family: var(--listitem-marker-font-family);
font-size: var(--listitem-marker-font-size);
}
The importDOM
implementation for TableCellNode
has been corrected to behave as other Lexical roots do with regard to converting <br>
tags to LineBreakNode
and wrapping runs of top-level inline nodes (including inline decorators) with ParagraphNode
. If you have any specific workarounds accounting for the previous behavior, you can remove them. The one difference from other import paths is that a solitary <br>
(e.g. <td><br></td>
) is converted to an empty ParagraphNode
rather than a ParagraphNode
containing a LineBreakNode
.
If you're using the undocumented internal getDOMSlot API, you may need to change your types. There is now a type parameter for ElementDOMSlot so that the element property can be specialized.
Core:
- 🆕 #7321 Add
mutatedNodes
toUpdateListener
payload - 🆕 #7323 Add a default delete handler for
NodeSelection
- this allowed a lot of boilerplate code to be deleted, and all of the existing implementations were subtly broken - ✅ #7341 Fix bug in transformer loop that would cause nodes not to get reconciled
- ✅ #7342 Handle
canBeEmpty()
in$splitNodes
- 🆕 #7344 Apply
RootNode
transforms last
List:
- ✅ #7325 Move
ListItemNode
text style inheritance to CSS custom properties
Tables:
- ✅ #7336 Fix updateDOM for scrollable TableNode
- ✅ #7318 Fix table cell line breaks
React:
- ✅ #7315 Remove unused direct dependencies
- 🆕 #7338 Add
onElementChanged
callback to DraggableBlockPlugin
Playground:
- ✅ #7337 Table actions should clear selection instead of moving it to the beginning
- 🆕 #7338 Add "+" button to DraggableBlockPlugin
Utils:
- 🆕 #7340 Add a type predicate to
objectKlassEquals
A mutatedNodes
property is now present in the UpdateListener
payload. This was done to accommodate the use case when you want to have a MutationListener that listens to all nodes (this is useful in combination with NodeState). Note that this property is only calculated when at least one MutationListener
is registered (e.g. editor.registerMutationListener(RootNode, () => {})
is sufficient to compute mutatedNodes
for all nodes).
NodeSelection.deleteNodes()
was added to support the default delete handler
There is now an ordering guarantee that RootNode node transforms are called last, and documentation about the special case that RootNode is always considered intentionally dirty when any other node is dirty
An onElementChanged
prop was added to make it possible to implement the "+" button in the playground
- v0.27.2 by @etrepum in https://github.com/facebook/lexical/pull/7314
- [lexical-react]: Chore: remove unused dependencies from @lexical/react by @AlessioGr in https://github.com/facebook/lexical/pull/7315
- [lexical-editor][Bug fix] Add LexicalEditor.hasNode to flow typing to match typescript by @Zhangerr in https://github.com/facebook/lexical/pull/7320
- [Breaking Change][lexical][lexical-table] Bug Fix: Scrollable TableNode updateDOM fixes and getDOMSlot type refactoring by @etrepum in https://github.com/facebook/lexical/pull/7336
- [lexical] Feature: Add mutatedNodes to UpdateListener payload by @etrepum in https://github.com/facebook/lexical/pull/7321
- [Breaking Change][lexical-list] Bug Fix: Move ListItemNode text style inheritance to custom properties and CSS by @etrepum in https://github.com/facebook/lexical/pull/7325
- [Breaking Change][lexical][lexical-playground] Feature: Add a default delete handler for NodeSelection by @etrepum in https://github.com/facebook/lexical/pull/7323
- [lexical-playground] Table actions should clear selection instead of moving it to the beginning by @etrepum in https://github.com/facebook/lexical/pull/7337
- [lexical-utils] Feature: Add type predicate to objectKlassEquals by @2wheeh in https://github.com/facebook/lexical/pull/7340
- [Breaking Change][lexical] Bug Fix: Fix bug in transformer loop that would cause nodes not to get reconciled by @etrepum in https://github.com/facebook/lexical/pull/7341
- [Breaking Change][lexical-table] Bug Fix: Table cell line breaks behave differently from the intended HTML behavior. by @dineug in https://github.com/facebook/lexical/pull/7318
- [Breaking Change][lexical][lexical-utils]: Bug Fix: Handle canBeEmpty in $splitNodes by @etrepum in https://github.com/facebook/lexical/pull/7342
- [lexical-playground][lexical-react] Feature: Push Draggable Element to Parent by @sescandell in https://github.com/facebook/lexical/pull/7338
- [lexical-website] Docs: Fix broken links to React Rich Collab Example by @etrepum in https://github.com/facebook/lexical/pull/7347
- [lexical] Feature: Apply RootNode transforms last by @etrepum in https://github.com/facebook/lexical/pull/7344
- @Zhangerr made their first contribution in https://github.com/facebook/lexical/pull/7320
- @dineug made their first contribution in https://github.com/facebook/lexical/pull/7318
- @sescandell made their first contribution in https://github.com/facebook/lexical/pull/7338
Full Changelog: https://github.com/facebook/lexical/compare/v0.27.2...v0.28.0
v0.27.2
v0.27.2 is an ad-hoc patch release to address the prismjs CVE (#7313). The way Lexical uses prismjs should not trigger that issue even in previous versions as it doesn't insert user generated HTML with "id" tags or use the autoloader plug-in, but it's good practice to keep up with security updates either way.
Code:
- ✅ #7313 Update prismjs dependency to 1.30.0
Collab:
- ✅ #7295 Prevent collab element nodes from removing other nodes from node map
Table:
- 🆕 #7297 Add table cell selection handler for touch devices
- ✅ #7309 Fix unintended touch table cell selection when scrolling
Playground:
- 🆕 #7299 Add touch support for TableCellResizer
- ✅ #7305 Fix row height resizing for merged cells
- v0.27.1 by @etrepum in https://github.com/facebook/lexical/pull/7288
- [lexical-website] Bug Fix: Fix vite.config.ts for gallery examples by @etrepum in https://github.com/facebook/lexical/pull/7290
- [lexical-yjs] Bug Fix: prevent collab element nodes from removing other nodes from node map by @james-atticus in https://github.com/facebook/lexical/pull/7295
- [lexical-playground] Feature: Add touch support for TableCellResizer by @ibastawisi in https://github.com/facebook/lexical/pull/7299
- [lexical-table] Add table cell selection handler for touch devices by @ibastawisi in https://github.com/facebook/lexical/pull/7297
- [lexical-playground] Bug Fix: row height resizing for merged cells by @kirandash in https://github.com/facebook/lexical/pull/7305
- [lexical-table] Bug Fix: Fix unintended touch table cell selection when scrolling by @ibastawisi in https://github.com/facebook/lexical/pull/7309
- [lexical-code] Chore: Update prismjs dependency to 1.30.0 by @etrepum in https://github.com/facebook/lexical/pull/7313
Full Changelog: https://github.com/facebook/lexical/compare/v0.27.1...v0.27.2
v0.27.1
v0.27.1 is an ad-hoc patch release to address the regression introduced in v0.26.0 with LexicalNode.getCommonAncestor
which occurs when calling node.getCommonAncestor(node)
when !$isElementNode(node)
(#7287).
Core:
- ✅ #7271 Fix non-ElementNode regression in getCommonAncestor
Core + List:
- ✅ #7282 Add RTL direction support in output HTML for ElementNode and ListItemNode (previously this was only on ParagraphNode)
Table:
- ✅ #7283 Fix click and drag table selection in Firefox
- v0.27.0 by @etrepum in https://github.com/facebook/lexical/pull/7281
- [lexical-list][lexical] Bug Fix: Add RTL direction support for list items in output HTML by @kirandash in https://github.com/facebook/lexical/pull/7282
- [lexical-table] Bug Fix: Click and drag table selection in Firefox by @etrepum in https://github.com/facebook/lexical/pull/7283
- [CI] Feature: Add a fixer for the no-imports-from-self lint by @etrepum in https://github.com/facebook/lexical/pull/7284
- [lexical] Bug Fix: Fix non-ElementNode regression in getCommonAncestor by @etrepum in https://github.com/facebook/lexical/pull/7287
Full Changelog: https://github.com/facebook/lexical/compare/v0.27.0...v0.27.1