UNPKG

@lexical/table

Version:

This package provides the Table feature for Lexical.

9 lines (8 loc) 56.4 kB
/** * Copyright (c) Meta Platforms, Inc. and affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * */ import{addClassNamesToElement as e,$descendantsMatching as t,$findMatchingParent as n,removeClassNamesFromElement as o,objectKlassEquals as r,isHTMLElement as l,$insertFirst as s,mergeRegister as i,$insertNodeToNearestRoot as c,$unwrapAndFilterDescendants as a}from"@lexical/utils";import{ElementNode as u,isHTMLElement as h,$isInlineElementOrDecoratorNode as d,$isTextNode as f,$isLineBreakNode as g,$createParagraphNode as m,$applyNodeReplacement as p,createCommand as _,$createTextNode as C,$getSelection as S,$isRangeSelection as w,$isParagraphNode as b,$createPoint as y,$isElementNode as N,$normalizeSelection__EXPERIMENTAL as v,isCurrentlyReadOnlyMode as x,TEXT_TYPE_TO_FORMAT as R,$getNodeByKey as T,$getEditor as F,$setSelection as O,SELECTION_CHANGE_COMMAND as A,getDOMSelection as K,$createRangeSelection as E,$isRootNode as k,INSERT_PARAGRAPH_COMMAND as M,COMMAND_PRIORITY_HIGH as $,KEY_ESCAPE_COMMAND as W,COMMAND_PRIORITY_CRITICAL as L,CUT_COMMAND as H,FORMAT_TEXT_COMMAND as z,FORMAT_ELEMENT_COMMAND as P,CONTROLLED_TEXT_INSERTION_COMMAND as B,KEY_TAB_COMMAND as D,FOCUS_COMMAND as I,SELECTION_INSERT_CLIPBOARD_NODES_COMMAND as U,$getPreviousSelection as J,$getNearestNodeFromDOMNode as Y,$createRangeSelectionFromDom as q,$isRootOrShadowRoot as X,KEY_ARROW_DOWN_COMMAND as j,KEY_ARROW_UP_COMMAND as V,KEY_ARROW_LEFT_COMMAND as G,KEY_ARROW_RIGHT_COMMAND as Q,DELETE_WORD_COMMAND as Z,DELETE_LINE_COMMAND as ee,DELETE_CHARACTER_COMMAND as te,KEY_BACKSPACE_COMMAND as ne,KEY_DELETE_COMMAND as oe,isDOMNode as re,$caretFromPoint as le,$isExtendableTextPointCaret as se,$extendCaretToRange as ie,$isSiblingCaret as ce,$getSiblingCaret as ae,$setPointFromCaret as ue,$normalizeCaret as he,$getAdjacentChildCaret as de,$isChildCaret as fe,$getChildCaret as ge,setDOMUnmanaged as me,COMMAND_PRIORITY_EDITOR as pe,CLICK_COMMAND as _e}from"lexical";import{copyToClipboard as Ce,$getClipboardDataFromSelection as Se}from"@lexical/clipboard";const we=/^(\d+(?:\.\d+)?)px$/,be={BOTH:3,COLUMN:2,NO_STATUS:0,ROW:1};class ye extends u{static getType(){return"tablecell"}static clone(e){return new ye(e.__headerState,e.__colSpan,e.__width,e.__key)}afterCloneFrom(e){super.afterCloneFrom(e),this.__rowSpan=e.__rowSpan,this.__backgroundColor=e.__backgroundColor,this.__verticalAlign=e.__verticalAlign}static importDOM(){return{td:e=>({conversion:ve,priority:0}),th:e=>({conversion:ve,priority:0})}}static importJSON(e){return xe().updateFromJSON(e)}updateFromJSON(e){return super.updateFromJSON(e).setHeaderStyles(e.headerState).setColSpan(e.colSpan||1).setRowSpan(e.rowSpan||1).setWidth(e.width||void 0).setBackgroundColor(e.backgroundColor||null).setVerticalAlign(e.verticalAlign||void 0)}constructor(e=be.NO_STATUS,t=1,n,o){super(o),this.__colSpan=t,this.__rowSpan=1,this.__headerState=e,this.__width=n,this.__backgroundColor=null,this.__verticalAlign=void 0}createDOM(t){const n=document.createElement(this.getTag());return this.__width&&(n.style.width=`${this.__width}px`),this.__colSpan>1&&(n.colSpan=this.__colSpan),this.__rowSpan>1&&(n.rowSpan=this.__rowSpan),null!==this.__backgroundColor&&(n.style.backgroundColor=this.__backgroundColor),Ne(this.__verticalAlign)&&(n.style.verticalAlign=this.__verticalAlign),e(n,t.theme.tableCell,this.hasHeader()&&t.theme.tableCellHeader),n}exportDOM(e){const t=super.exportDOM(e);if(h(t.element)){const e=t.element;e.setAttribute("data-temporary-table-cell-lexical-key",this.getKey()),e.style.border="1px solid black",this.__colSpan>1&&(e.colSpan=this.__colSpan),this.__rowSpan>1&&(e.rowSpan=this.__rowSpan),e.style.width=`${this.getWidth()||75}px`,e.style.verticalAlign=this.getVerticalAlign()||"top",e.style.textAlign="start",null===this.__backgroundColor&&this.hasHeader()&&(e.style.backgroundColor="#f2f3f5")}return t}exportJSON(){return{...super.exportJSON(),...Ne(this.__verticalAlign)&&{verticalAlign:this.__verticalAlign},backgroundColor:this.getBackgroundColor(),colSpan:this.__colSpan,headerState:this.__headerState,rowSpan:this.__rowSpan,width:this.getWidth()}}getColSpan(){return this.getLatest().__colSpan}setColSpan(e){const t=this.getWritable();return t.__colSpan=e,t}getRowSpan(){return this.getLatest().__rowSpan}setRowSpan(e){const t=this.getWritable();return t.__rowSpan=e,t}getTag(){return this.hasHeader()?"th":"td"}setHeaderStyles(e,t=be.BOTH){const n=this.getWritable();return n.__headerState=e&t|n.__headerState&~t,n}getHeaderStyles(){return this.getLatest().__headerState}setWidth(e){const t=this.getWritable();return t.__width=e,t}getWidth(){return this.getLatest().__width}getBackgroundColor(){return this.getLatest().__backgroundColor}setBackgroundColor(e){const t=this.getWritable();return t.__backgroundColor=e,t}getVerticalAlign(){return this.getLatest().__verticalAlign}setVerticalAlign(e){const t=this.getWritable();return t.__verticalAlign=e||void 0,t}toggleHeaderStyle(e){const t=this.getWritable();return(t.__headerState&e)===e?t.__headerState-=e:t.__headerState+=e,t}hasHeaderState(e){return(this.getHeaderStyles()&e)===e}hasHeader(){return this.getLatest().__headerState!==be.NO_STATUS}updateDOM(e){return e.__headerState!==this.__headerState||e.__width!==this.__width||e.__colSpan!==this.__colSpan||e.__rowSpan!==this.__rowSpan||e.__backgroundColor!==this.__backgroundColor||e.__verticalAlign!==this.__verticalAlign}isShadowRoot(){return!0}collapseAtStart(){return!0}canBeEmpty(){return!1}canIndent(){return!1}}function Ne(e){return"middle"===e||"bottom"===e}function ve(e){const t=e,n=e.nodeName.toLowerCase();let o;we.test(t.style.width)&&(o=parseFloat(t.style.width));const r=xe("th"===n?be.ROW:be.NO_STATUS,t.colSpan,o);r.__rowSpan=t.rowSpan;const l=t.style.backgroundColor;""!==l&&(r.__backgroundColor=l);const s=t.style.verticalAlign;Ne(s)&&(r.__verticalAlign=s);const i=t.style,c=(i&&i.textDecoration||"").split(" "),a="700"===i.fontWeight||"bold"===i.fontWeight,u=c.includes("line-through"),h="italic"===i.fontStyle,p=c.includes("underline");return{after:e=>{const t=[];let n=null;const o=()=>{if(n){const e=n.getFirstChild();g(e)&&1===n.getChildrenSize()&&e.remove()}};for(const r of e)d(r)||f(r)||g(r)?(f(r)&&(a&&r.toggleFormat("bold"),u&&r.toggleFormat("strikethrough"),h&&r.toggleFormat("italic"),p&&r.toggleFormat("underline")),n?n.append(r):(n=m().append(r),t.push(n))):(t.push(r),o(),n=null);return o(),0===t.length&&t.push(m()),t},node:r}}function xe(e=be.NO_STATUS,t=1,n){return p(new ye(e,t,n))}function Re(e){return e instanceof ye}const Te=_("INSERT_TABLE_COMMAND");function Fe(e,...t){const n=new URL("https://lexical.dev/docs/error"),o=new URLSearchParams;o.append("code",e);for(const e of t)o.append("v",e);throw n.search=o.toString(),Error(`Minified Lexical error #${e}; visit ${n.toString()} for the full message or use the non-minified dev environment for full errors and additional helpful warnings.`)}class Oe extends u{static getType(){return"tablerow"}static clone(e){return new Oe(e.__height,e.__key)}static importDOM(){return{tr:e=>({conversion:Ae,priority:0})}}static importJSON(e){return Ke().updateFromJSON(e)}updateFromJSON(e){return super.updateFromJSON(e).setHeight(e.height)}constructor(e,t){super(t),this.__height=e}exportJSON(){const e=this.getHeight();return{...super.exportJSON(),...void 0===e?void 0:{height:e}}}createDOM(t){const n=document.createElement("tr");return this.__height&&(n.style.height=`${this.__height}px`),e(n,t.theme.tableRow),n}extractWithChild(e,t,n){return"html"===n}isShadowRoot(){return!0}setHeight(e){const t=this.getWritable();return t.__height=e,t}getHeight(){return this.getLatest().__height}updateDOM(e){return e.__height!==this.__height}canBeEmpty(){return!1}canIndent(){return!1}}function Ae(e){const n=e;let o;return we.test(n.style.height)&&(o=parseFloat(n.style.height)),{after:e=>t(e,Re),node:Ke(o)}}function Ke(e){return p(new Oe(e))}function Ee(e){return e instanceof Oe}const ke="undefined"!=typeof window&&void 0!==window.document&&void 0!==window.document.createElement,Me=ke&&"documentMode"in document?document.documentMode:null,$e=ke&&/^(?!.*Seamonkey)(?=.*Firefox).*/i.test(navigator.userAgent);function We(e,t,n=!0){const o=dn();for(let r=0;r<e;r++){const e=Ke();for(let o=0;o<t;o++){let t=be.NO_STATUS;"object"==typeof n?(0===r&&n.rows&&(t|=be.ROW),0===o&&n.columns&&(t|=be.COLUMN)):n&&(0===r&&(t|=be.ROW),0===o&&(t|=be.COLUMN));const l=xe(t),s=m();s.append(C()),l.append(s),e.append(l)}o.append(e)}return o}function Le(e){const t=n(e,(e=>Re(e)));return Re(t)?t:null}function He(e){const t=n(e,(e=>Ee(e)));if(Ee(t))return t;throw new Error("Expected table cell to be inside of table row.")}function ze(e){const t=n(e,(e=>fn(e)));if(fn(t))return t;throw new Error("Expected table cell to be inside of table.")}function Pe(e){const t=He(e);return ze(t).getChildren().findIndex((e=>e.is(t)))}function Be(e){return He(e).getChildren().findIndex((t=>t.is(e)))}function De(e,t){const n=ze(e),{x:o,y:r}=n.getCordsFromCellNode(e,t);return{above:n.getCellNodeFromCords(o,r-1,t),below:n.getCellNodeFromCords(o,r+1,t),left:n.getCellNodeFromCords(o-1,r,t),right:n.getCellNodeFromCords(o+1,r,t)}}function Ie(e,t){const n=e.getChildren();if(t>=n.length||t<0)throw new Error("Expected table cell to be inside of table row.");return n[t].remove(),e}function Ue(e,t,n=!0,o,r){const l=e.getChildren();if(t>=l.length||t<0)throw new Error("Table row target index out of range");const s=l[t];if(!Ee(s))throw new Error("Row before insertion index does not exist.");for(let e=0;e<o;e++){const e=s.getChildren(),t=e.length,o=Ke();for(let n=0;n<t;n++){const t=e[n];Re(t)||Fe(12);const{above:l,below:s}=De(t,r);let i=be.NO_STATUS;const c=l&&l.getWidth()||s&&s.getWidth()||void 0;(l&&l.hasHeaderState(be.COLUMN)||s&&s.hasHeaderState(be.COLUMN))&&(i|=be.COLUMN);const a=xe(i,1,c);a.append(m()),o.append(a)}n?s.insertAfter(o):s.insertBefore(o)}return e}ke&&"InputEvent"in window&&!Me&&new window.InputEvent("input");const Je=(e,t)=>e===be.BOTH||e===t?t:be.NO_STATUS;function Ye(e=!0){const t=S();w(t)||_t(t)||Fe(188);const n=t.anchor.getNode(),o=t.focus.getNode(),[r]=dt(n),[l,,s]=dt(o),[,i,c]=ut(s,l,r),{startRow:a}=c,{startRow:u}=i;return e?Xe(a+r.__rowSpan>u+l.__rowSpan?r:l,!0):Xe(u<a?l:r,!1)}const qe=Ye;function Xe(e,t=!0){const[,,n]=dt(e),[o,r]=ut(n,e,e),l=o[0].length,{startRow:s}=r;let i=null;if(t){const t=s+e.__rowSpan-1,r=o[t],c=Ke();for(let e=0;e<l;e++){const{cell:n,startRow:o}=r[e];if(o+n.__rowSpan-1<=t){const t=r[e].cell.__headerState,n=Je(t,be.COLUMN);c.append(xe(n).append(m()))}else n.setRowSpan(n.__rowSpan+1)}const a=n.getChildAtIndex(t);Ee(a)||Fe(256),a.insertAfter(c),i=c}else{const e=s,t=o[e],r=Ke();for(let n=0;n<l;n++){const{cell:o,startRow:l}=t[n];if(l===e){const e=t[n].cell.__headerState,o=Je(e,be.COLUMN);r.append(xe(o).append(m()))}else o.setRowSpan(o.__rowSpan+1)}const c=n.getChildAtIndex(e);Ee(c)||Fe(257),c.insertBefore(r),i=r}return i}function je(e,t,n=!0,o,r){const l=e.getChildren(),s=[];for(let e=0;e<l.length;e++){const n=l[e];if(Ee(n))for(let e=0;e<o;e++){const e=n.getChildren();if(t>=e.length||t<0)throw new Error("Table column target index out of range");const o=e[t];Re(o)||Fe(12);const{left:l,right:i}=De(o,r);let c=be.NO_STATUS;(l&&l.hasHeaderState(be.ROW)||i&&i.hasHeaderState(be.ROW))&&(c|=be.ROW);const a=xe(c);a.append(m()),s.push({newTableCell:a,targetCell:o})}}return s.forEach((({newTableCell:e,targetCell:t})=>{n?t.insertAfter(e):t.insertBefore(e)})),e}function Ve(e=!0){const t=S();w(t)||_t(t)||Fe(188);const n=t.anchor.getNode(),o=t.focus.getNode(),[r]=dt(n),[l,,s]=dt(o),[,i,c]=ut(s,l,r),{startColumn:a}=c,{startColumn:u}=i;return e?Qe(a+r.__colSpan>u+l.__colSpan?r:l,!0):Qe(u<a?l:r,!1)}const Ge=Ve;function Qe(e,t=!0,n=!0){const[,,o]=dt(e),[r,l]=ut(o,e,e),s=r.length,{startColumn:i}=l,c=t?i+e.__colSpan-1:i-1,a=o.getFirstChild();Ee(a)||Fe(120);let u=null;function h(e=be.NO_STATUS){const t=xe(e).append(m());return null===u&&(u=t),t}let d=a;e:for(let e=0;e<s;e++){if(0!==e){const e=d.getNextSibling();Ee(e)||Fe(121),d=e}const t=r[e],n=t[c<0?0:c].cell.__headerState,o=Je(n,be.ROW);if(c<0){lt(d,h(o));continue}const{cell:l,startColumn:s,startRow:i}=t[c];if(s+l.__colSpan-1<=c){let n=l,r=i,s=c;for(;r!==e&&n.__rowSpan>1;){if(s-=l.__colSpan,!(s>=0)){d.append(h(o));continue e}{const{cell:e,startRow:o}=t[s];n=e,r=o}}n.insertAfter(h(o))}else l.setColSpan(l.__colSpan+1)}null!==u&&n&&rt(u);const f=o.getColWidths();if(f){const e=[...f],t=c<0?0:c,n=e[t];e.splice(t,0,n),o.setColWidths(e)}return u}function Ze(e,t){const n=e.getChildren();for(let e=0;e<n.length;e++){const o=n[e];if(Ee(o)){const e=o.getChildren();if(t>=e.length||t<0)throw new Error("Table column target index out of range");e[t].remove()}}return e}function et(){const e=S();w(e)||_t(e)||Fe(188);const[t,n]=e.isBackward()?[e.focus.getNode(),e.anchor.getNode()]:[e.anchor.getNode(),e.focus.getNode()],[o,,r]=dt(t),[l]=dt(n),[s,i,c]=ut(r,o,l),{startRow:a}=i,{startRow:u}=c,h=u+l.__rowSpan-1;if(s.length===h-a+1)return void r.remove();const d=s[0].length,f=o.__rowSpan,g=s[h+1],m=r.getChildAtIndex(h+1);for(let e=h;e>=a;e--){for(let t=d-1;t>=0;t--){const{cell:n,startRow:o,startColumn:r}=s[e][t];if(r===t){if(e===a&&o<a){const e=a-o;n.setRowSpan(n.__rowSpan-Math.min(f,n.__rowSpan-e))}if(o>=a&&o+n.__rowSpan-1>h){n.setRowSpan(n.__rowSpan-(h-o+1)),null===m&&Fe(122);let r=null;for(let n=0;n<t;n++){const t=g[n],o=t.cell;t.startRow===e+1&&(r=o),o.__colSpan>1&&(n+=o.__colSpan-1)}null===r?lt(m,n):r.insertAfter(n)}}}const t=r.getChildAtIndex(e);Ee(t)||Fe(206,String(e)),t.remove()}if(void 0!==g){const{cell:e}=g[0];rt(e)}else{const e=s[a-1],{cell:t}=e[0];rt(t)}}const tt=et;function nt(){const e=S();w(e)||_t(e)||Fe(188);const t=e.anchor.getNode(),n=e.focus.getNode(),[o,,r]=dt(t),[l]=dt(n),[s,i,c]=ut(r,o,l),{startColumn:a}=i,{startRow:u,startColumn:h}=c,d=Math.min(a,h),f=Math.max(a+o.__colSpan-1,h+l.__colSpan-1),g=f-d+1;if(s[0].length===f-d+1)return r.selectPrevious(),void r.remove();const m=s.length;for(let e=0;e<m;e++)for(let t=d;t<=f;t++){const{cell:n,startColumn:o}=s[e][t];if(o<d){if(t===d){const e=d-o;n.setColSpan(n.__colSpan-Math.min(g,n.__colSpan-e))}}else if(o+n.__colSpan-1>f){if(t===f){const e=f-o+1;n.setColSpan(n.__colSpan-e)}}else n.remove()}const p=s[u],_=a>h?p[a+o.__colSpan]:p[h+l.__colSpan];if(void 0!==_){const{cell:e}=_;rt(e)}else{const e=h<a?p[h-1]:p[a-1],{cell:t}=e;rt(t)}const C=r.getColWidths();if(C){const e=[...C];e.splice(d,g),r.setColWidths(e)}}const ot=nt;function rt(e){const t=e.getFirstDescendant();null==t?e.selectStart():t.getParentOrThrow().selectStart()}function lt(e,t){const n=e.getFirstChild();null!==n?n.insertBefore(t):e.append(t)}function st(e){if(0===e.length)return null;const t=ze(e[0]),[n]=ht(t,null,null);let o=1/0,r=-1/0,l=1/0,s=-1/0;const i=new Set;for(const t of n)for(const n of t){if(!n||!n.cell)continue;const t=n.cell.getKey();if(!i.has(t)&&e.some((e=>e.is(n.cell)))){i.add(t);const e=n.startRow,c=n.startColumn,a=n.cell.__rowSpan||1,u=n.cell.__colSpan||1;o=Math.min(o,e),r=Math.max(r,e+a-1),l=Math.min(l,c),s=Math.max(s,c+u-1)}}if(o===1/0||l===1/0)return null;const c=r-o+1,a=s-l+1,u=n[o][l];if(!u.cell)return null;const h=u.cell;h.setColSpan(a),h.setRowSpan(c);const d=new Set([h.getKey()]);for(let e=o;e<=r;e++)for(let t=l;t<=s;t++){const o=n[e][t];if(!o.cell)continue;const r=o.cell,l=r.getKey();if(!d.has(l)){d.add(l);it(r)||h.append(...r.getChildren()),r.remove()}}return 0===h.getChildrenSize()&&h.append(m()),h}function it(e){if(1!==e.getChildrenSize())return!1;const t=e.getFirstChildOrThrow();return!(!b(t)||!t.isEmpty())}function ct(){const e=S();w(e)||_t(e)||Fe(188);const t=e.anchor.getNode(),o=n(t,Re);return Re(o)||Fe(148),at(o)}function at(e){const[t,n,o]=dt(e),r=t.__colSpan,l=t.__rowSpan;if(1===r&&1===l)return;const[s,i]=ut(o,t,t),{startColumn:c,startRow:a}=i,u=t.__headerState&be.COLUMN,h=Array.from({length:r},((e,t)=>{let n=u;for(let e=0;0!==n&&e<s.length;e++)n&=s[e][t+c].cell.__headerState;return n})),d=t.__headerState&be.ROW,f=Array.from({length:l},((e,t)=>{let n=d;for(let e=0;0!==n&&e<s[0].length;e++)n&=s[t+a][e].cell.__headerState;return n}));if(r>1){for(let e=1;e<r;e++)t.insertAfter(xe(h[e]|f[0]).append(m()));t.setColSpan(1)}if(l>1){let e;for(let t=1;t<l;t++){const o=a+t,l=s[o];e=(e||n).getNextSibling(),Ee(e)||Fe(125);let i=null;for(let e=0;e<c;e++){const t=l[e],n=t.cell;t.startRow===o&&(i=n),n.__colSpan>1&&(e+=n.__colSpan-1)}if(null===i)for(let n=r-1;n>=0;n--)lt(e,xe(h[n]|f[t]).append(m()));else for(let e=r-1;e>=0;e--)i.insertAfter(xe(h[e]|f[t]).append(m()))}t.setRowSpan(1)}}function ut(e,t,n){const[o,r,l]=ht(e,t,n);return null===r&&Fe(207),null===l&&Fe(208),[o,r,l]}function ht(e,t,n){const o=[];let r=null,l=null;function s(e){let t=o[e];return void 0===t&&(o[e]=t=[]),t}const i=e.getChildren();for(let e=0;e<i.length;e++){const o=i[e];Ee(o)||Fe(209);const c=s(e);for(let a=o.getFirstChild(),u=0;null!=a;a=a.getNextSibling()){for(Re(a)||Fe(147);void 0!==c[u];)u++;const o={cell:a,startColumn:u,startRow:e},{__rowSpan:h,__colSpan:d}=a;for(let t=0;t<h&&!(e+t>=i.length);t++){const n=s(e+t);for(let e=0;e<d;e++)n[u+e]=o}null!==t&&null===r&&t.is(a)&&(r=o),null!==n&&null===l&&n.is(a)&&(l=o)}}return[o,r,l]}function dt(e){let t;if(e instanceof ye)t=e;else if("__type"in e){const o=n(e,Re);Re(o)||Fe(148),t=o}else{const o=n(e.getNode(),Re);Re(o)||Fe(148),t=o}const o=t.getParent();Ee(o)||Fe(149);const r=o.getParent();return fn(r)||Fe(210),[t,o,r]}function ft(e,t,n){let o,r=Math.min(t.startColumn,n.startColumn),l=Math.min(t.startRow,n.startRow),s=Math.max(t.startColumn+t.cell.__colSpan-1,n.startColumn+n.cell.__colSpan-1),i=Math.max(t.startRow+t.cell.__rowSpan-1,n.startRow+n.cell.__rowSpan-1);do{o=!1;for(let t=0;t<e.length;t++)for(let n=0;n<e[0].length;n++){const c=e[t][n];if(!c)continue;const a=c.startColumn+c.cell.__colSpan-1,u=c.startRow+c.cell.__rowSpan-1,h=c.startColumn<=s&&a>=r,d=c.startRow<=i&&u>=l;if(h&&d){const e=Math.min(r,c.startColumn),t=Math.max(s,a),n=Math.min(l,c.startRow),h=Math.max(i,u);e===r&&t===s&&n===l&&h===i||(r=e,s=t,l=n,i=h,o=!0)}}}while(o);return{maxColumn:s,maxRow:i,minColumn:r,minRow:l}}function gt(e){const[t,,n]=dt(e),o=n.getChildren(),r=o.length,l=o[0].getChildren().length,s=new Array(r);for(let e=0;e<r;e++)s[e]=new Array(l);for(let e=0;e<r;e++){const n=o[e].getChildren();let r=0;for(let o=0;o<n.length;o++){for(;s[e][r];)r++;const l=n[o],i=l.__rowSpan||1,c=l.__colSpan||1;for(let t=0;t<i;t++)for(let n=0;n<c;n++)s[e+t][r+n]=l;if(t===l)return{colSpan:c,columnIndex:r,rowIndex:e,rowSpan:i};r+=c}}return null}function mt(e){const[[t,o,r,l],[s,i,c,a]]=["anchor","focus"].map((t=>{const o=e[t].getNode(),r=n(o,Re);Re(r)||Fe(238,t,o.getKey(),o.getType());const l=r.getParent();Ee(l)||Fe(239,t);const s=l.getParent();return fn(s)||Fe(240,t),[o,r,l,s]}));return l.is(a)||Fe(241),{anchorCell:o,anchorNode:t,anchorRow:r,anchorTable:l,focusCell:i,focusNode:s,focusRow:c,focusTable:a}}class pt{constructor(e,t,n){this.anchor=t,this.focus=n,t._selection=this,n._selection=this,this._cachedNodes=null,this.dirty=!1,this.tableKey=e}getStartEndPoints(){return[this.anchor,this.focus]}isValid(){return"root"!==this.tableKey&&"root"!==this.anchor.key&&"element"===this.anchor.type&&"root"!==this.focus.key&&"element"===this.focus.type}isBackward(){return this.focus.isBefore(this.anchor)}getCachedNodes(){return this._cachedNodes}setCachedNodes(e){this._cachedNodes=e}is(e){return _t(e)&&this.tableKey===e.tableKey&&this.anchor.is(e.anchor)&&this.focus.is(e.focus)}set(e,t,n){this.dirty=this.dirty||e!==this.tableKey||t!==this.anchor.key||n!==this.focus.key,this.tableKey=e,this.anchor.key=t,this.focus.key=n,this._cachedNodes=null}clone(){return new pt(this.tableKey,y(this.anchor.key,this.anchor.offset,this.anchor.type),y(this.focus.key,this.focus.offset,this.focus.type))}isCollapsed(){return!1}extract(){return this.getNodes()}insertRawText(e){}insertText(){}hasFormat(e){let t=0;this.getNodes().filter(Re).forEach((e=>{const n=e.getFirstChild();b(n)&&(t|=n.getTextFormat())}));const n=R[e];return!!(t&n)}insertNodes(e){const t=this.focus.getNode();N(t)||Fe(151);v(t.select(0,t.getChildrenSize())).insertNodes(e)}getShape(){const{anchorCell:e,focusCell:t}=mt(this),n=gt(e);null===n&&Fe(153);const o=gt(t);null===o&&Fe(155);const r=Math.min(n.columnIndex,o.columnIndex),l=Math.max(n.columnIndex+n.colSpan-1,o.columnIndex+o.colSpan-1),s=Math.min(n.rowIndex,o.rowIndex),i=Math.max(n.rowIndex+n.rowSpan-1,o.rowIndex+o.rowSpan-1);return{fromX:Math.min(r,l),fromY:Math.min(s,i),toX:Math.max(r,l),toY:Math.max(s,i)}}getNodes(){if(!this.isValid())return[];const e=this._cachedNodes;if(null!==e)return e;const{anchorTable:t,anchorCell:n,focusCell:o}=mt(this),r=o.getParents()[1];if(r!==t){if(t.isParentOf(o)){const e=r.getParent();null==e&&Fe(159),this.set(this.tableKey,o.getKey(),e.getKey())}else{const e=t.getParent();null==e&&Fe(158),this.set(this.tableKey,e.getKey(),o.getKey())}return this.getNodes()}const[l,s,i]=ut(t,n,o),{minColumn:c,maxColumn:a,minRow:u,maxRow:h}=ft(l,s,i),d=new Map([[t.getKey(),t]]);let f=null;for(let e=u;e<=h;e++)for(let t=c;t<=a;t++){const{cell:n}=l[e][t],o=n.getParent();Ee(o)||Fe(160),o!==f&&(d.set(o.getKey(),o),f=o),d.has(n.getKey())||wt(n,(e=>{d.set(e.getKey(),e)}))}const g=Array.from(d.values());return x()||(this._cachedNodes=g),g}getTextContent(){const e=this.getNodes().filter((e=>Re(e)));let t="";for(let n=0;n<e.length;n++){const o=e[n],r=o.__parent,l=(e[n+1]||{}).__parent;t+=o.getTextContent()+(l!==r?"\n":"\t")}return t}}function _t(e){return e instanceof pt}function Ct(){const e=y("root",0,"element"),t=y("root",0,"element");return new pt("root",e,t)}function St(e,t,n){e.getKey(),t.getKey(),n.getKey();const o=S(),r=_t(o)?o.clone():Ct();return r.set(e.getKey(),t.getKey(),n.getKey()),r}function wt(e,t){const n=[[e]];for(let e=n.at(-1);void 0!==e&&n.length>0;e=n.at(-1)){const o=e.pop();void 0===o?n.pop():!1!==t(o)&&N(o)&&n.push(o.getChildren())}}function bt(e,t=F()){const n=T(e);fn(n)||Fe(231,e);const o=Rt(n,t.getElementByKey(e));return null===o&&Fe(232,e),{tableElement:o,tableNode:n}}class yt{constructor(e,t){this.isHighlightingCells=!1,this.anchorX=-1,this.anchorY=-1,this.focusX=-1,this.focusY=-1,this.listenersToRemove=new Set,this.tableNodeKey=t,this.editor=e,this.table={columns:0,domRows:[],rows:0},this.tableSelection=null,this.anchorCellNodeKey=null,this.focusCellNodeKey=null,this.anchorCell=null,this.focusCell=null,this.hasHijackedSelectionStyles=!1,this.isSelecting=!1,this.pointerType=null,this.shouldCheckSelection=!1,this.abortController=new AbortController,this.listenerOptions={signal:this.abortController.signal},this.nextFocus=null,this.trackTable()}getTable(){return this.table}removeListeners(){this.abortController.abort("removeListeners"),Array.from(this.listenersToRemove).forEach((e=>e())),this.listenersToRemove.clear()}$lookup(){return bt(this.tableNodeKey,this.editor)}trackTable(){const e=new MutationObserver((e=>{this.editor.getEditorState().read((()=>{let t=!1;for(let n=0;n<e.length;n++){const o=e[n].target.nodeName;if("TABLE"===o||"TBODY"===o||"THEAD"===o||"TR"===o){t=!0;break}}if(!t)return;const{tableNode:n,tableElement:o}=this.$lookup();this.table=Wt(n,o)}),{editor:this.editor})}));this.editor.getEditorState().read((()=>{const{tableNode:t,tableElement:n}=this.$lookup();this.table=Wt(t,n),e.observe(n,{attributes:!0,childList:!0,subtree:!0})}),{editor:this.editor})}$clearHighlight(){const e=this.editor;this.isHighlightingCells=!1,this.anchorX=-1,this.anchorY=-1,this.focusX=-1,this.focusY=-1,this.tableSelection=null,this.anchorCellNodeKey=null,this.focusCellNodeKey=null,this.anchorCell=null,this.focusCell=null,this.hasHijackedSelectionStyles=!1,this.$enableHighlightStyle();const{tableNode:t,tableElement:n}=this.$lookup();Lt(e,Wt(t,n),null),null!==S()&&(O(null),e.dispatchCommand(A,void 0))}$enableHighlightStyle(){const e=this.editor,{tableElement:t}=this.$lookup();o(t,e._config.theme.tableSelection),t.classList.remove("disable-selection"),this.hasHijackedSelectionStyles=!1}$disableHighlightStyle(){const{tableElement:t}=this.$lookup();e(t,this.editor._config.theme.tableSelection),this.hasHijackedSelectionStyles=!0}$updateTableTableSelection(e){if(null!==e){e.tableKey!==this.tableNodeKey&&Fe(233,e.tableKey,this.tableNodeKey);const t=this.editor;this.tableSelection=e,this.isHighlightingCells=!0,this.$disableHighlightStyle(),this.updateDOMSelection(),Lt(t,this.table,this.tableSelection)}else this.$clearHighlight()}setShouldCheckSelection(){this.shouldCheckSelection=!0}getAndClearShouldCheckSelection(){return!!this.shouldCheckSelection&&(this.shouldCheckSelection=!1,!0)}setNextFocus(e){this.nextFocus=e}getAndClearNextFocus(){const{nextFocus:e}=this;return null!==e&&(this.nextFocus=null),e}updateDOMSelection(){if(null!==this.anchorCell&&null!==this.focusCell){const e=K(this.editor._window);e&&e.rangeCount>0&&e.removeAllRanges()}}$setFocusCellForSelection(e,t=!1){const n=this.editor,{tableNode:o}=this.$lookup(),r=e.x,l=e.y;if(this.focusCell=e,this.isHighlightingCells||this.anchorX===r&&this.anchorY===l&&!t){if(r===this.focusX&&l===this.focusY)return!1}else this.isHighlightingCells=!0,this.$disableHighlightStyle();if(this.focusX=r,this.focusY=l,this.isHighlightingCells){const t=on(o,e.elem);if(null!=this.tableSelection&&null!=this.anchorCellNodeKey&&null!==t)return this.focusCellNodeKey=t.getKey(),this.tableSelection=St(o,this.$getAnchorTableCellOrThrow(),t),O(this.tableSelection),n.dispatchCommand(A,void 0),Lt(n,this.table,this.tableSelection),!0}return!1}$getAnchorTableCell(){return this.anchorCellNodeKey?T(this.anchorCellNodeKey):null}$getAnchorTableCellOrThrow(){const e=this.$getAnchorTableCell();return null===e&&Fe(234),e}$getFocusTableCell(){return this.focusCellNodeKey?T(this.focusCellNodeKey):null}$getFocusTableCellOrThrow(){const e=this.$getFocusTableCell();return null===e&&Fe(235),e}$setAnchorCellForSelection(e){this.isHighlightingCells=!1,this.anchorCell=e,this.anchorX=e.x,this.anchorY=e.y;const{tableNode:t}=this.$lookup(),n=on(t,e.elem);if(null!==n){const e=n.getKey();this.tableSelection=null!=this.tableSelection?this.tableSelection.clone():Ct(),this.anchorCellNodeKey=e}}$formatCells(e){const t=S();_t(t)||Fe(236);const n=E(),o=n.anchor,r=n.focus,l=t.getNodes().filter(Re);l.length>0||Fe(237);const s=l[0].getFirstChild(),i=b(s)?s.getFormatFlags(e,null):null;l.forEach((t=>{o.set(t.getKey(),0,"element"),r.set(t.getKey(),t.getChildrenSize(),"element"),n.formatText(e,i)})),O(t),this.editor.dispatchCommand(A,void 0)}$clearText(){const{editor:e}=this,t=T(this.tableNodeKey);if(!fn(t))throw new Error("Expected TableNode.");const n=S();_t(n)||Fe(253);const o=n.getNodes().filter(Re);if(o.length===this.table.columns*this.table.rows){t.selectPrevious();const n=t.getParent();return t.remove(),void(k(n)&&n.isEmpty()&&e.dispatchCommand(M,void 0))}o.forEach((e=>{if(N(e)){const t=m(),n=C();t.append(n),e.append(t),e.getChildren().forEach((e=>{e!==t&&e.remove()}))}})),Lt(e,this.table,null),O(null),e.dispatchCommand(A,void 0)}}const Nt="__lexicalTableSelection",vt=e=>!(1&~e.buttons);function xt(e){return h(e)&&"TABLE"===e.nodeName}function Rt(e,t){if(!t)return t;const n=xt(t)?t:e.getDOMSlot(t).element;return"TABLE"!==n.nodeName&&Fe(245,t.nodeName),n}function Tt(e){return e._window}function Ft(e,t){for(let n=t,o=null;null!==n;n=n.getParent()){if(e.is(n))return o;Re(n)&&(o=n)}return null}const Ot=[[j,"down"],[V,"up"],[G,"backward"],[Q,"forward"]],At=[Z,ee,te],Kt=[ne,oe];function Et(e,t,o,l){const s=o.getRootElement(),i=Tt(o);null!==s&&null!==i||Fe(246);const c=new yt(o,e.getKey()),a=Rt(e,t);!function(e,t){null!==kt(e)&&Fe(205);e[Nt]=t}(a,c),c.listenersToRemove.add((()=>function(e,t){kt(e)===t&&delete e[Nt]}(a,c)));const u=t=>{if(c.pointerType=t.pointerType,0!==t.button||!re(t.target)||!i)return;const n=Mt(t.target);null!==n&&o.update((()=>{const o=J();if($e&&t.shiftKey&&Jt(o,e)&&(w(o)||_t(o))){const r=o.anchor.getNode(),l=Ft(e,o.anchor.getNode());if(l)c.$setAnchorCellForSelection(nn(c,l)),c.$setFocusCellForSelection(n),Zt(t);else{(e.isBefore(r)?e.selectStart():e.selectEnd()).anchor.set(o.anchor.key,o.anchor.offset,o.anchor.type)}}else c.$setAnchorCellForSelection(n)})),(()=>{if(c.isSelecting)return;const e=()=>{c.isSelecting=!1,i.removeEventListener("pointerup",e),i.removeEventListener("pointermove",t)},t=n=>{if(!vt(n)&&c.isSelecting)return c.isSelecting=!1,i.removeEventListener("pointerup",e),void i.removeEventListener("pointermove",t);if(!re(n.target))return;let r=null;const l=!($e||a.contains(n.target));if(l)r=$t(a,n.target);else for(const e of document.elementsFromPoint(n.clientX,n.clientY))if(r=$t(a,e),r)break;!r||null!==c.focusCell&&r.elem===c.focusCell.elem||(c.setNextFocus({focusCell:r,override:l}),o.dispatchCommand(A,void 0))};c.isSelecting=!0,i.addEventListener("pointerup",e,c.listenerOptions),i.addEventListener("pointermove",t,c.listenerOptions)})()};a.addEventListener("pointerdown",u,c.listenerOptions),c.listenersToRemove.add((()=>{a.removeEventListener("pointerdown",u)}));const h=e=>{if(e.detail>=3&&re(e.target)){null!==Mt(e.target)&&e.preventDefault()}};a.addEventListener("mousedown",h,c.listenerOptions),c.listenersToRemove.add((()=>{a.removeEventListener("mousedown",h)}));const d=e=>{const t=e.target;0===e.button&&re(t)&&o.update((()=>{const e=S();_t(e)&&e.tableKey===c.tableNodeKey&&s.contains(t)&&c.$clearHighlight()}))};i.addEventListener("pointerdown",d,c.listenerOptions),c.listenersToRemove.add((()=>{i.removeEventListener("pointerdown",d)}));for(const[t,n]of Ot)c.listenersToRemove.add(o.registerCommand(t,(t=>Qt(o,t,n,e,c)),$));c.listenersToRemove.add(o.registerCommand(W,(t=>{const n=S();if(_t(n)){const o=Ft(e,n.focus.getNode());if(null!==o)return Zt(t),o.selectEnd(),!0}return!1}),$));const g=t=>()=>{const o=S();if(!Jt(o,e))return!1;if(_t(o))return c.$clearText(),!0;if(w(o)){if(!Re(Ft(e,o.anchor.getNode())))return!1;const r=o.anchor.getNode(),l=o.focus.getNode(),s=e.isParentOf(r),i=e.isParentOf(l);if(s&&!i||i&&!s)return c.$clearText(),!0;const a=n(o.anchor.getNode(),(e=>N(e))),u=a&&n(a,(e=>N(e)&&Re(e.getParent())));if(!N(u)||!N(a))return!1;if(t===ee&&null===u.getPreviousSibling())return!0}return!1};for(const e of At)c.listenersToRemove.add(o.registerCommand(e,g(e),L));const p=t=>{const n=S();if(!_t(n)&&!w(n))return!1;const o=e.isParentOf(n.anchor.getNode());if(o!==e.isParentOf(n.focus.getNode())){const t=o?"anchor":"focus",r=o?"focus":"anchor",{key:l,offset:s,type:i}=n[r];return e[n[t].isBefore(n[r])?"selectPrevious":"selectNext"]()[r].set(l,s,i),!1}return!!Jt(n,e)&&(!!_t(n)&&(t&&(t.preventDefault(),t.stopPropagation()),c.$clearText(),!0))};for(const e of Kt)c.listenersToRemove.add(o.registerCommand(e,p,L));return c.listenersToRemove.add(o.registerCommand(H,(e=>{const t=S();if(t){if(!_t(t)&&!w(t))return!1;Ce(o,r(e,ClipboardEvent)?e:null,Se(t));const n=p(e);return w(t)?(t.removeText(),!0):n}return!1}),L)),c.listenersToRemove.add(o.registerCommand(z,(t=>{const o=S();if(!Jt(o,e))return!1;if(_t(o))return c.$formatCells(t),!0;if(w(o)){const e=n(o.anchor.getNode(),(e=>Re(e)));if(!Re(e))return!1}return!1}),L)),c.listenersToRemove.add(o.registerCommand(P,(t=>{const n=S();if(!_t(n)||!Jt(n,e))return!1;const o=n.anchor.getNode(),r=n.focus.getNode();if(!Re(o)||!Re(r))return!1;if(function(e,t){if(_t(e)){const n=e.anchor.getNode(),o=e.focus.getNode();if(t&&n&&o){const[e]=ut(t,n,o);return n.getKey()===e[0][0].cell.getKey()&&o.getKey()===e[e.length-1].at(-1).cell.getKey()}}return!1}(n,e))return e.setFormat(t),!0;const[l,s,i]=ut(e,o,r),c=Math.max(s.startRow+s.cell.__rowSpan-1,i.startRow+i.cell.__rowSpan-1),a=Math.max(s.startColumn+s.cell.__colSpan-1,i.startColumn+i.cell.__colSpan-1),u=Math.min(s.startRow,i.startRow),h=Math.min(s.startColumn,i.startColumn),d=new Set;for(let e=u;e<=c;e++)for(let n=h;n<=a;n++){const o=l[e][n].cell;if(d.has(o))continue;d.add(o),o.setFormat(t);const r=o.getChildren();for(let e=0;e<r.length;e++){const n=r[e];N(n)&&!n.isInline()&&n.setFormat(t)}}return!0}),L)),c.listenersToRemove.add(o.registerCommand(B,(t=>{const r=S();if(!Jt(r,e))return!1;if(_t(r))return c.$clearHighlight(),!1;if(w(r)){const l=n(r.anchor.getNode(),(e=>Re(e)));if(!Re(l))return!1;if("string"==typeof t){const n=tn(o,r,e);if(n)return en(n,e,[C(t)]),!0}}return!1}),L)),l&&c.listenersToRemove.add(o.registerCommand(D,(t=>{const o=S();if(!w(o)||!o.isCollapsed()||!Jt(o,e))return!1;const r=jt(o.anchor.getNode());return!(null===r||!e.is(Vt(r)))&&(Zt(t),function(e,t){const o="next"===t?"getNextSibling":"getPreviousSibling",r="next"===t?"getFirstChild":"getLastChild",l=e[o]();if(N(l))return l.selectEnd();const s=n(e,Ee);null===s&&Fe(247);for(let e=s[o]();Ee(e);e=e[o]()){const t=e[r]();if(N(t))return t.selectEnd()}const i=n(s,fn);null===i&&Fe(248);"next"===t?i.selectNext():i.selectPrevious()}(r,t.shiftKey?"previous":"next"),!0)}),L)),c.listenersToRemove.add(o.registerCommand(I,(t=>e.isSelected()),$)),c.listenersToRemove.add(o.registerCommand(U,(e=>{const{nodes:t,selection:o}=e,r=o.getStartEndPoints(),l=_t(o),s=w(o)&&null!==n(o.anchor.getNode(),(e=>Re(e)))&&null!==n(o.focus.getNode(),(e=>Re(e)))||l;if(1!==t.length||!fn(t[0])||!s||null===r)return!1;const[i,c]=r,[a,u,h]=dt(i),d=n(c.getNode(),(e=>Re(e)));if(!(Re(a)&&Re(d)&&Ee(u)&&fn(h)))return!1;const g=t[0],[p,_,C]=ut(h,a,d),[S]=ht(g,null,null),b=p.length,y=b>0?p[0].length:0;let N=_.startRow,v=_.startColumn,x=S.length,R=x>0?S[0].length:0;if(l){const e=ft(p,_,C),t=e.maxRow-e.minRow+1,n=e.maxColumn-e.minColumn+1;N=e.minRow,v=e.minColumn,x=Math.min(x,t),R=Math.min(R,n)}let T=!1;const F=Math.min(b,N+x)-1,O=Math.min(y,v+R)-1,A=new Set;for(let e=N;e<=F;e++)for(let t=v;t<=O;t++){const n=p[e][t];A.has(n.cell.getKey())||(1===n.cell.__rowSpan&&1===n.cell.__colSpan||(at(n.cell),A.add(n.cell.getKey()),T=!0))}let[K]=ht(h.getWritable(),null,null);const E=x-b+N;for(let e=0;e<E;e++){Xe(K[b-1][0].cell)}const k=R-y+v;for(let e=0;e<k;e++){Qe(K[0][y-1].cell,!0,!1)}[K]=ht(h.getWritable(),null,null);for(let e=N;e<N+x;e++)for(let t=v;t<v+R;t++){const n=e-N,o=t-v,r=S[n][o];if(r.startRow!==n||r.startColumn!==o)continue;const l=r.cell;if(1!==l.__rowSpan||1!==l.__colSpan){const n=[],o=Math.min(e+l.__rowSpan,N+x)-1,r=Math.min(t+l.__colSpan,v+R)-1;for(let l=e;l<=o;l++)for(let e=t;e<=r;e++){const t=K[l][e];n.push(t.cell)}st(n),T=!0}const{cell:s}=K[e][t],i=s.getChildren();l.getChildren().forEach((e=>{if(f(e)){m().append(e),s.append(e)}else s.append(e)})),i.forEach((e=>e.remove()))}if(l&&T){const[e]=ht(h.getWritable(),null,null);e[_.startRow][_.startColumn].cell.selectEnd()}return!0}),L)),c.listenersToRemove.add(o.registerCommand(A,(()=>{const t=S(),r=J(),l=c.getAndClearNextFocus();if(null!==l){const{focusCell:n}=l;if(_t(t)&&t.tableKey===c.tableNodeKey)return(n.x!==c.focusX||n.y!==c.focusY)&&(c.$setFocusCellForSelection(n),!0);if(n!==c.anchorCell&&Jt(t,e))return c.$setFocusCellForSelection(n),!0}if(c.getAndClearShouldCheckSelection()&&w(r)&&w(t)&&t.isCollapsed()){const o=t.anchor.getNode(),r=e.getFirstChild(),l=jt(o);if(null!==l&&Ee(r)){const t=r.getFirstChild();if(Re(t)&&e.is(n(l,(n=>n.is(e)||n.is(t)))))return t.selectStart(),!0}}if(w(t)){const{anchor:n,focus:l}=t,s=n.getNode(),i=l.getNode(),a=jt(s),u=jt(i),h=!(!a||!e.is(Vt(a))),d=!(!u||!e.is(Vt(u))),f=h!==d,g=h&&d,m=t.isBackward();if(f){const n=t.clone();if(d){const[t]=ut(e,u,u),o=t[0][0].cell,r=t[t.length-1].at(-1).cell;n.focus.set(m?o.getKey():r.getKey(),m?o.getChildrenSize():r.getChildrenSize(),"element")}else if(h){const[t]=ut(e,a,a),o=t[0][0].cell,r=t[t.length-1].at(-1).cell;n.anchor.set(m?r.getKey():o.getKey(),m?r.getChildrenSize():0,"element")}O(n),zt(o,c)}else if(g&&(a.is(u)||(c.$setAnchorCellForSelection(nn(c,a)),c.$setFocusCellForSelection(nn(c,u),!0)),"touch"===c.pointerType&&t.isCollapsed()&&w(r)&&r.isCollapsed())){const e=jt(r.anchor.getNode());e&&!e.is(u)&&(c.$setAnchorCellForSelection(nn(c,e)),c.$setFocusCellForSelection(nn(c,u),!0),c.pointerType=null)}}else if(t&&_t(t)&&t.is(r)&&t.tableKey===e.getKey()){const n=K(i);if(n&&n.anchorNode&&n.focusNode){const r=Y(n.focusNode),l=r&&!e.isParentOf(r),s=Y(n.anchorNode),i=s&&e.isParentOf(s);if(l&&i&&n.rangeCount>0){const r=q(n,o);r&&(r.anchor.set(e.getKey(),t.isBackward()?e.getChildrenSize():0,"element"),n.removeAllRanges(),O(r))}}}return t&&!t.is(r)&&(_t(t)||_t(r))&&c.tableSelection&&!c.tableSelection.is(r)?(_t(t)&&t.tableKey===c.tableNodeKey?c.$updateTableTableSelection(t):!_t(t)&&_t(r)&&r.tableKey===c.tableNodeKey&&c.$updateTableTableSelection(null),!1):(c.hasHijackedSelectionStyles&&!e.isSelected()?function(e,t){t.$enableHighlightStyle(),Ht(t.table,(t=>{const n=t.elem;t.highlighted=!1,Xt(e,t),n.getAttribute("style")||n.removeAttribute("style")}))}(o,c):!c.hasHijackedSelectionStyles&&e.isSelected()&&zt(o,c),!1)}),L)),c.listenersToRemove.add(o.registerCommand(M,(()=>{const t=S();if(!w(t)||!t.isCollapsed()||!Jt(t,e))return!1;const n=tn(o,t,e);return!!n&&(en(n,e),!0)}),L)),c}function kt(e){return e[Nt]||null}function Mt(e){let t=e;for(;null!=t;){const e=t.nodeName;if("TD"===e||"TH"===e){const e=t._cell;return void 0===e?null:e}t=t.parentNode}return null}function $t(e,t){if(!e.contains(t))return null;let n=null;for(let o=t;null!=o;o=o.parentNode){if(o===e)return n;const t=o.nodeName;"TD"!==t&&"TH"!==t||(n=o._cell||null)}return null}function Wt(e,t){const n=[],o={columns:0,domRows:n,rows:0};let r=Rt(e,t).querySelector("tr"),l=0,s=0;for(n.length=0;null!=r;){const e=r.nodeName;if("TD"===e||"TH"===e){const e={elem:r,hasBackgroundColor:""!==r.style.backgroundColor,highlighted:!1,x:l,y:s};r._cell=e;let t=n[s];void 0===t&&(t=n[s]=[]),t[l]=e}else{const e=r.firstChild;if(null!=e){r=e;continue}}const t=r.nextSibling;if(null!=t){l++,r=t;continue}const o=r.parentNode;if(null!=o){const e=o.nextSibling;if(null==e)break;s++,l=0,r=e}}return o.columns=l+1,o.rows=s+1,o}function Lt(e,t,n){const o=new Set(n?n.getNodes():[]);Ht(t,((t,n)=>{const r=t.elem;o.has(n)?(t.highlighted=!0,qt(e,t)):(t.highlighted=!1,Xt(e,t),r.getAttribute("style")||r.removeAttribute("style"))}))}function Ht(e,t){const{domRows:n}=e;for(let e=0;e<n.length;e++){const o=n[e];if(o)for(let n=0;n<o.length;n++){const r=o[n];if(!r)continue;const l=Y(r.elem);null!==l&&t(r,l,{x:n,y:e})}}}function zt(e,t){t.$disableHighlightStyle(),Ht(t.table,(t=>{t.highlighted=!0,qt(e,t)}))}const Pt=(e,t,n,o,r)=>{const l="forward"===r;switch(r){case"backward":case"forward":return n!==(l?e.table.columns-1:0)?Yt(t.getCellNodeFromCordsOrThrow(n+(l?1:-1),o,e.table),l):o!==(l?e.table.rows-1:0)?Yt(t.getCellNodeFromCordsOrThrow(l?0:e.table.columns-1,o+(l?1:-1),e.table),l):l?t.selectNext():t.selectPrevious(),!0;case"up":return 0!==o?Yt(t.getCellNodeFromCordsOrThrow(n,o-1,e.table),!1):t.selectPrevious(),!0;case"down":return o!==e.table.rows-1?Yt(t.getCellNodeFromCordsOrThrow(n,o+1,e.table),!0):t.selectNext(),!0;default:return!1}};function Bt(e,t){let n,o;if(t.startColumn===e.minColumn)n="minColumn";else{if(t.startColumn+t.cell.__colSpan-1!==e.maxColumn)return null;n="maxColumn"}if(t.startRow===e.minRow)o="minRow";else{if(t.startRow+t.cell.__rowSpan-1!==e.maxRow)return null;o="maxRow"}return[n,o]}function Dt([e,t]){return["minColumn"===e?"maxColumn":"minColumn","minRow"===t?"maxRow":"minRow"]}function It(e,t,[n,o]){const r=t[o],l=e[r];void 0===l&&Fe(250,o,String(r));const s=t[n],i=l[s];return void 0===i&&Fe(250,n,String(s)),i}function Ut(e,t,n,o,r){const l=ft(t,n,o),s=function(e,t){const{minColumn:n,maxColumn:o,minRow:r,maxRow:l}=t;let s=1,i=1,c=1,a=1;const u=e[r],h=e[l];for(let e=n;e<=o;e++)s=Math.max(s,u[e].cell.__rowSpan),a=Math.max(a,h[e].cell.__rowSpan);for(let t=r;t<=l;t++)i=Math.max(i,e[t][n].cell.__colSpan),c=Math.max(c,e[t][o].cell.__colSpan);return{bottomSpan:a,leftSpan:i,rightSpan:c,topSpan:s}}(t,l),{topSpan:i,leftSpan:c,bottomSpan:a,rightSpan:u}=s,h=function(e,t){const n=Bt(e,t);return null===n&&Fe(249,t.cell.getKey()),n}(l,n),[d,f]=Dt(h);let g=l[d],m=l[f];"forward"===r?g+="maxColumn"===d?1:c:"backward"===r?g-="minColumn"===d?1:u:"down"===r?m+="maxRow"===f?1:i:"up"===r&&(m-="minRow"===f?1:a);const p=t[m];if(void 0===p)return!1;const _=p[g];if(void 0===_)return!1;const[C,S]=function(e,t,n){const o=ft(e,t,n),r=Bt(o,t);if(r)return[It(e,o,r),It(e,o,Dt(r))];const l=Bt(o,n);if(l)return[It(e,o,Dt(l)),It(e,o,l)];const s=["minColumn","minRow"];return[It(e,o,s),It(e,o,Dt(s))]}(t,n,_),w=nn(e,C.cell),b=nn(e,S.cell);return e.$setAnchorCellForSelection(w),e.$setFocusCellForSelection(b,!0),!0}function Jt(e,t){if(w(e)||_t(e)){const n=t.isParentOf(e.anchor.getNode()),o=t.isParentOf(e.focus.getNode());return n&&o}return!1}function Yt(e,t){t?e.selectStart():e.selectEnd()}function qt(t,n){const o=n.elem,r=t._config.theme;Re(Y(o))||Fe(131),e(o,r.tableCellSelected)}function Xt(e,t){const n=t.elem;Re(Y(n))||Fe(131);const r=e._config.theme;o(n,r.tableCellSelected)}function jt(e){const t=n(e,Re);return Re(t)?t:null}function Vt(e){const t=n(e,fn);return fn(t)?t:null}function Gt(e,t,o,r,l,s,i){const c=le(o.focus,l?"previous":"next");if(se(c))return!1;let a=c;for(const e of ie(c).iterNodeCarets("shadowRoot")){if(!ce(e)||!N(e.origin))return!1;a=e}const u=a.getParentAtCaret();if(!Re(u))return!1;const h=u,d=function(e){for(const t of ie(e).iterNodeCarets("root")){const{origin:n}=t;if(Re(n)){if(fe(t))return ge(n,e.direction)}else if(!Ee(n))break}return null}(ae(h,a.direction)),f=n(h,fn);if(!f||!f.is(s))return!1;const g=e.getElementByKey(h.getKey()),m=Mt(g);if(!g||!m)return!1;const p=un(e,f);if(i.table=p,d)if("extend"===r){const t=Mt(e.getElementByKey(d.origin.getKey()));if(!t)return!1;i.$setAnchorCellForSelection(m),i.$setFocusCellForSelection(t,!0)}else{const e=he(d);ue(o.anchor,e),ue(o.focus,e)}else if("extend"===r)i.$setAnchorCellForSelection(m),i.$setFocusCellForSelection(m,!0);else{const e=function(e){const t=de(e);return fe(t)?he(t):e}(ae(f,c.direction));ue(o.anchor,e),ue(o.focus,e)}return Zt(t),!0}function Qt(e,t,o,r,l){if(("up"===o||"down"===o)&&function(e){const t=e.getRootElement();if(!t)return!1;return t.hasAttribute("aria-controls")&&"typeahead-menu"===t.getAttribute("aria-controls")}(e))return!1;const s=S();if(!Jt(s,r)){if(w(s)){if("backward"===o){if(s.focus.offset>0)return!1;const e=function(e){for(let t=e,n=e;null!==n;t=n,n=n.getParent())if(N(n)){if(n!==t&&n.getFirstChild()!==t)return null;if(!n.isInline())return n}return null}(s.focus.getNode());if(!e)return!1;const n=e.getPreviousSibling();return!!fn(n)&&(Zt(t),t.shiftKey?s.focus.set(n.getParentOrThrow().getKey(),n.getIndexWithinParent(),"element"):n.selectEnd(),!0)}if(t.shiftKey&&("up"===o||"down"===o)){const e=s.focus.getNode();if(!s.isCollapsed()&&("up"===o&&!s.isBackward()||"down"===o&&s.isBackward())){let l=n(e,(e=>fn(e)));if(Re(l)&&(l=n(l,fn)),l!==r)return!1;if(!l)return!1;const i="down"===o?l.getNextSibling():l.getPreviousSibling();if(!i)return!1;let c=0;"up"===o&&N(i)&&(c=i.getChildrenSize());let a=i;if("up"===o&&N(i)){const e=i.getLastChild();a=e||i,c=f(a)?a.getTextContentSize():0}const u=s.clone();return u.focus.set(a.getKey(),c,f(a)?"text":"element"),O(u),Zt(t),!0}if(X(e)){const e="up"===o?s.getNodes()[s.getNodes().length-1]:s.getNodes()[0];if(e){if(null!==Ft(r,e)){const e=r.getFirstDescendant(),t=r.getLastDescendant();if(!e||!t)return!1;const[n]=dt(e),[o]=dt(t),s=r.getCordsFromCellNode(n,l.table),i=r.getCordsFromCellNode(o,l.table),c=r.getDOMCellFromCordsOrThrow(s.x,s.y,l.table),a=r.getDOMCellFromCordsOrThrow(i.x,i.y,l.table);return l.$setAnchorCellForSelection(c),l.$setFocusCellForSelection(a,!0),!0}}return!1}{let r=n(e,(e=>N(e)&&!e.isInline()));if(Re(r)&&(r=n(r,fn)),!r)return!1;const i="down"===o?r.getNextSibling():r.getPreviousSibling();if(fn(i)&&l.tableNodeKey===i.getKey()){const e=i.getFirstDescendant(),n=i.getLastDescendant();if(!e||!n)return!1;const[r]=dt(e),[l]=dt(n),c=s.clone();return c.focus.set(("up"===o?r:l).getKey(),"up"===o?0:l.getChildrenSize(),"element"),Zt(t),O(c),!0}}}}return"down"===o&&sn(e)&&l.setShouldCheckSelection(),!1}if(w(s)){if("backward"===o||"forward"===o){return Gt(e,t,s,t.shiftKey?"extend":"move","backward"===o,r,l)}if(s.isCollapsed()){const{anchor:i,focus:c}=s,a=n(i.getNode(),Re),u=n(c.getNode(),Re);if(!Re(a)||!a.is(u))return!1;const h=Vt(a);if(h!==r&&null!=h){const n=Rt(h,e.getElementByKey(h.getKey()));if(null!=n)return l.table=Wt(h,n),Qt(e,t,o,h,l)}const d=e.getElementByKey(a.__key),f=e.getElementByKey(i.key);if(null==f||null==d)return!1;let g;if("element"===i.type)g=f.getBoundingClientRect();else{const t=K(Tt(e));if(null===t||0===t.rangeCount)return!1;g=t.getRangeAt(0).getBoundingClientRect()}const m="up"===o?a.getFirstChild():a.getLastChild();if(null==m)return!1;const p=e.getElementByKey(m.__key);if(null==p)return!1;const _=p.getBoundingClientRect();if("up"===o?_.top>g.top-g.height:g.bottom+g.height>_.bottom){Zt(t);const e=r.getCordsFromCellNode(a,l.table);if(!t.shiftKey)return Pt(l,r,e.x,e.y,o);{const t=r.getDOMCellFromCordsOrThrow(e.x,e.y,l.table);l.$setAnchorCellForSelection(t),l.$setFocusCellForSelection(t,!0)}return!0}}}else if(_t(s)){const{anchor:i,focus:c}=s,a=n(i.getNode(),Re),u=n(c.getNode(),Re),[h]=s.getNodes();fn(h)||Fe(251);const d=Rt(h,e.getElementByKey(h.getKey()));if(!Re(a)||!Re(u)||!fn(h)||null==d)return!1;l.$updateTableTableSelection(s);const f=Wt(h,d),g=r.getCordsFromCellNode(a,f),m=r.getDOMCellFromCordsOrThrow(g.x,g.y,f);if(l.$setAnchorCellForSelection(m),Zt(t),t.shiftKey){const[e,t,n]=ut(r,a,u);return Ut(l,e,t,n,o)}return u.selectEnd(),!0}return!1}function Zt(e){e.preventDefault(),e.stopImmediatePropagation(),e.stopPropagation()}function en(e,t,n){const o=m();"first"===e?t.insertBefore(o):t.insertAfter(o),o.append(...n||[]),o.selectEnd()}function tn(e,t,o){const r=o.getParent();if(!r)return;const l=K(Tt(e));if(!l)return;const s=l.anchorNode,i=e.getElementByKey(r.getKey()),c=Rt(o,e.getElementByKey(o.getKey()));if(!s||!i||!c||!i.contains(s)||c.contains(s))return;const a=n(t.anchor.getNode(),(e=>Re(e)));if(!a)return;const u=n(a,(e=>fn(e)));if(!fn(u)||!u.is(o))return;const[h,d]=ut(o,a,a),f=h[0][0],g=h[h.length-1][h[0].length-1],{startRow:m,startColumn:p}=d,_=m===f.startRow&&p===f.startColumn,C=m===g.startRow&&p===g.startColumn;return _?"first":C?"last":void 0}function nn(e,t){const{tableNode:n}=e.$lookup(),o=n.getCordsFromCellNode(t,e.table);return n.getDOMCellFromCordsOrThrow(o.x,o.y,e.table)}function on(e,t,n){return Ft(e,Y(t,n))}function rn(t,n,r){if(!n.theme.tableAlignment)return;const l=[],s=[];for(const e of["center","right"]){const t=n.theme.tableAlignment[e];t&&(e===r?s:l).push(t)}o(t,...l),e(t,...s)}const ln=new WeakSet;function sn(e=F()){return ln.has(e)}function cn(e,t){t?ln.add(e):ln.delete(e)}class an extends u{static getType(){return"table"}getColWidths(){return this.getLatest().__colWidths}setColWidths(e){const t=this.getWritable();return t.__colWidths=e,t}static clone(e){return new an(e.__key)}afterCloneFrom(e){super.afterCloneFrom(e),this.__colWidths=e.__colWidths,this.__rowStriping=e.__rowStriping,this.__frozenColumnCount=e.__frozenColumnCount,this.__frozenRowCount=e.__frozenRowCount}static importDOM(){return{table:e=>({conversion:hn,priority:1})}}static importJSON(e){return dn().updateFromJSON(e)}updateFromJSON(e){return super.updateFromJSON(e).setRowStriping(e.rowStriping||!1).setFrozenColumns(e.frozenColumnCount||0).setFrozenRows(e.frozenRowCount||0).setColWidths(e.colWidths)}constructor(e){super(e),this.__rowStriping=!1,this.__frozenColumnCount=0,this.__frozenRowCount=0}exportJSON(){return{...super.exportJSON(),colWidths:this.getColWidths(),frozenColumnCount:this.__frozenColumnCount?this.__frozenColumnCount:void 0,frozenRowCount:this.__frozenRowCount?this.__frozenRowCount:void 0,rowStriping:this.__rowStriping?this.__rowStriping:void 0}}extractWithChild(e,t,n){return"html"===n}getDOMSlot(e){const t=xt(e)?e:e.querySelector("table");return xt(t)||Fe(229),super.getDOMSlot(e).withElement(t).withAfter(t.querySelector("colgroup"))}createDOM(t,n){const o=document.createElement("table");this.__style&&(o.style.cssText=this.__style);const r=document.createElement("colgroup");if(o.appendChild(r),me(r),e(o,t.theme.table),this.updateTableElement(null,o,t),sn(n)){const n=document.createElement("div"),r=t.theme.tableScrollableWrapper;return r?e(n,r):n.style.cssText="overflow-x: auto;",n.appendChild(o),this.updateTableWrapper(null,n,o,t),n}return o}updateTableWrapper(t,n,r,l){this.__frozenColumnCount!==(t?t.__frozenColumnCount:0)&&function(t,n,r,l){l>0?(e(t,r.theme.tableFrozenColumn),n.setAttribute("data-lexical-frozen-column","true")):(o(t,r.theme.tableFrozenColumn),n.removeAttribute("data-lexical-frozen-column"))}(n,r,l,this.__frozenColumnCount),this.__frozenRowCount!==(t?t.__frozenRowCount:0)&&function(t,n,r,l){l>0?(e(t,r.theme.tableFrozenRow),n.setAttribute("data-lexical-frozen-row","true")):(o(t,r.theme.tableFrozenRow),n.removeAttribute("data-lexical-frozen-row"))}(n,r,l,this.__frozenRowCount)}updateTableElement(t,n,r){this.__style!==(t?t.__style:"")&&(n.style.cssText=this.__style),this.__rowStriping!==(!!t&&t.__rowStriping)&&function(t,n,r){r?(e(t,n.theme.tableRowStriping),t.setAttribute("data-lexical-row-striping","true")):(o(t,n.theme.tableRowStriping),t.removeAttribute("data-lexical-row-striping"))}(n,r,this.__rowStriping),function(e,t,n,o){const r=e.querySelector("colgroup");if(!r)return;const l=[];for(let e=0;e<n;e++){const t=document.createElement("col"),n=o&&o[e];n&&(t.style.width=`${n}px`),l.push(t)}r.replaceChildren(...l)}(n,0,this.getColumnCount(),this.getColWidths()),rn(n,r,this.getFormatType())}updateDOM(e,t,n){const o=this.getDOMSlot(t).element;var r;return l(r=t)&&"DIV"===r.nodeName&&this.updateTableWrapper(e,t,o,n),this.updateTableElement(e,this.getDOMSlot(t).element,n),!1}exportDOM(e){const t=super.exportDOM(e),{element:n}=t;return{after:n=>{if(t.after&&(n=t.after(n)),!xt(n)&&l(n)&&(n=n.querySelector("table")),!xt(n))return null;rn(n,e._config,this.getFormatType());const[o]=ht(this,null,null),r=new Map;for(const e of o)for(const t of e){const e=t.cell.getKey();r.has(e)||r.set(e,{colSpan:t.cell.getColSpan(),startColumn:t.startColumn})}const s=new Set;for(const e of n.querySelect