reactjs-tiptap-editor 0.3.25 → 0.3.27
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/{ActionMenuButton-Bh2ft7th.js → ActionMenuButton-D3nLtawn.js} +1 -1
- package/lib/{ActionMenuButton-B3XOtCey.cjs → ActionMenuButton-fkh63F_R.cjs} +1 -1
- package/lib/Attachment.cjs +1 -1
- package/lib/Attachment.d.cts +26 -17
- package/lib/Attachment.d.ts +26 -17
- package/lib/Attachment.js +1 -1
- package/lib/Blockquote.cjs +1 -1
- package/lib/Blockquote.d.cts +26 -17
- package/lib/Blockquote.d.ts +26 -17
- package/lib/Blockquote.js +1 -1
- package/lib/Bold.cjs +1 -1
- package/lib/Bold.d.cts +26 -17
- package/lib/Bold.d.ts +26 -17
- package/lib/Bold.js +1 -1
- package/lib/BulletList.cjs +1 -1
- package/lib/BulletList.d.cts +26 -17
- package/lib/BulletList.d.ts +26 -17
- package/lib/BulletList.js +1 -1
- package/lib/Clear.cjs +1 -1
- package/lib/Clear.d.cts +26 -17
- package/lib/Clear.d.ts +26 -17
- package/lib/Clear.js +1 -1
- package/lib/Code.cjs +1 -1
- package/lib/Code.d.cts +26 -17
- package/lib/Code.d.ts +26 -17
- package/lib/Code.js +1 -1
- package/lib/CodeBlock.cjs +1 -1
- package/lib/CodeBlock.d.cts +26 -17
- package/lib/CodeBlock.d.ts +26 -17
- package/lib/CodeBlock.js +1 -1
- package/lib/CodeView.cjs +1 -1
- package/lib/CodeView.d.cts +26 -17
- package/lib/CodeView.d.ts +26 -17
- package/lib/CodeView.js +1 -1
- package/lib/Color.cjs +1 -1
- package/lib/Color.d.cts +26 -17
- package/lib/Color.d.ts +26 -17
- package/lib/Color.js +1 -1
- package/lib/Document.d.cts +26 -17
- package/lib/Document.d.ts +26 -17
- package/lib/{Drawer-Orz21MYs.js → Drawer-BBVUujX4.js} +1 -1
- package/lib/{Drawer-CUntRzbs.cjs → Drawer-DetzmUvQ.cjs} +1 -1
- package/lib/Drawer.cjs +1 -1
- package/lib/Drawer.d.cts +26 -17
- package/lib/Drawer.d.ts +26 -17
- package/lib/Drawer.js +2 -2
- package/lib/Emoji.cjs +1 -1
- package/lib/Emoji.d.cts +26 -17
- package/lib/Emoji.d.ts +26 -17
- package/lib/Emoji.js +1 -1
- package/lib/{Excalidraw-Cj-sXq5F.js → Excalidraw-BVdio4hk.js} +1 -1
- package/lib/{Excalidraw-Bu8XuykT.cjs → Excalidraw-DVnwdz-w.cjs} +1 -1
- package/lib/Excalidraw.cjs +1 -1
- package/lib/Excalidraw.d.cts +26 -17
- package/lib/Excalidraw.d.ts +26 -17
- package/lib/Excalidraw.js +1 -1
- package/lib/ExportPdf.cjs +4 -4
- package/lib/ExportPdf.d.cts +27 -17
- package/lib/ExportPdf.d.ts +27 -17
- package/lib/ExportPdf.js +34 -27
- package/lib/ExportWord.cjs +1 -1
- package/lib/ExportWord.d.cts +26 -17
- package/lib/ExportWord.d.ts +26 -17
- package/lib/ExportWord.js +1 -1
- package/lib/FontFamily.cjs +1 -1
- package/lib/FontFamily.d.cts +26 -17
- package/lib/FontFamily.d.ts +26 -17
- package/lib/FontFamily.js +2 -2
- package/lib/FontSize.cjs +1 -1
- package/lib/FontSize.d.cts +26 -17
- package/lib/FontSize.d.ts +26 -17
- package/lib/FontSize.js +2 -2
- package/lib/FormatPainter.cjs +1 -1
- package/lib/FormatPainter.d.cts +26 -17
- package/lib/FormatPainter.d.ts +26 -17
- package/lib/FormatPainter.js +1 -1
- package/lib/Heading.cjs +1 -1
- package/lib/Heading.d.cts +26 -17
- package/lib/Heading.d.ts +26 -17
- package/lib/Heading.js +2 -2
- package/lib/Highlight.cjs +1 -1
- package/lib/Highlight.d.cts +26 -17
- package/lib/Highlight.d.ts +26 -17
- package/lib/Highlight.js +1 -1
- package/lib/History.cjs +1 -1
- package/lib/History.d.cts +26 -17
- package/lib/History.d.ts +26 -17
- package/lib/History.js +1 -1
- package/lib/HorizontalRule.cjs +1 -1
- package/lib/HorizontalRule.d.cts +26 -17
- package/lib/HorizontalRule.d.ts +26 -17
- package/lib/HorizontalRule.js +1 -1
- package/lib/Iframe.cjs +1 -1
- package/lib/Iframe.d.cts +26 -17
- package/lib/Iframe.d.ts +26 -17
- package/lib/Iframe.js +1 -1
- package/lib/Image.cjs +1 -1
- package/lib/Image.d.cts +26 -17
- package/lib/Image.d.ts +26 -17
- package/lib/Image.js +1 -1
- package/lib/ImageGif.cjs +1 -1
- package/lib/ImageGif.d.cts +26 -17
- package/lib/ImageGif.d.ts +26 -17
- package/lib/ImageGif.js +1 -1
- package/lib/ImportWord.cjs +1 -1
- package/lib/ImportWord.d.cts +26 -17
- package/lib/ImportWord.d.ts +26 -17
- package/lib/ImportWord.js +1 -1
- package/lib/Indent.cjs +1 -1
- package/lib/Indent.d.cts +26 -17
- package/lib/Indent.d.ts +26 -17
- package/lib/Indent.js +1 -1
- package/lib/Italic.cjs +1 -1
- package/lib/Italic.d.cts +26 -17
- package/lib/Italic.d.ts +26 -17
- package/lib/Italic.js +1 -1
- package/lib/Katex.cjs +1 -1
- package/lib/Katex.d.cts +26 -17
- package/lib/Katex.d.ts +26 -17
- package/lib/Katex.js +2 -2
- package/lib/LineHeight.cjs +1 -1
- package/lib/LineHeight.d.cts +26 -17
- package/lib/LineHeight.d.ts +26 -17
- package/lib/LineHeight.js +1 -1
- package/lib/Link.cjs +1 -1
- package/lib/Link.d.cts +26 -17
- package/lib/Link.d.ts +26 -17
- package/lib/Link.js +1 -1
- package/lib/ListItem.d.cts +26 -17
- package/lib/ListItem.d.ts +26 -17
- package/lib/Mention.d.cts +26 -17
- package/lib/Mention.d.ts +26 -17
- package/lib/Mermaid.cjs +1 -1
- package/lib/Mermaid.d.cts +26 -17
- package/lib/Mermaid.d.ts +26 -17
- package/lib/Mermaid.js +2 -2
- package/lib/MoreMark.cjs +1 -1
- package/lib/MoreMark.d.cts +26 -17
- package/lib/MoreMark.d.ts +26 -17
- package/lib/MoreMark.js +1 -1
- package/lib/MultiColumn.cjs +1 -1
- package/lib/MultiColumn.d.cts +26 -17
- package/lib/MultiColumn.d.ts +26 -17
- package/lib/MultiColumn.js +1 -1
- package/lib/OrderedList.cjs +1 -1
- package/lib/OrderedList.d.cts +26 -17
- package/lib/OrderedList.d.ts +26 -17
- package/lib/OrderedList.js +1 -1
- package/lib/{RichTextEditor-CfAFp9V2.js → RichTextEditor-BJWhWz4z.js} +1460 -1446
- package/lib/{RichTextEditor-B5WYnm7K.cjs → RichTextEditor-DoMu_nCj.cjs} +7 -7
- package/lib/SearchAndReplace.cjs +1 -1
- package/lib/SearchAndReplace.d.cts +26 -17
- package/lib/SearchAndReplace.d.ts +26 -17
- package/lib/SearchAndReplace.js +1 -1
- package/lib/Selection.d.cts +26 -17
- package/lib/Selection.d.ts +26 -17
- package/lib/SlashCommand.cjs +1 -1
- package/lib/SlashCommand.d.cts +26 -17
- package/lib/SlashCommand.d.ts +26 -17
- package/lib/SlashCommand.js +1 -1
- package/lib/Strike.cjs +1 -1
- package/lib/Strike.d.cts +26 -17
- package/lib/Strike.d.ts +26 -17
- package/lib/Strike.js +1 -1
- package/lib/SubAndSuperScript.cjs +1 -1
- package/lib/SubAndSuperScript.d.cts +26 -17
- package/lib/SubAndSuperScript.d.ts +26 -17
- package/lib/SubAndSuperScript.js +1 -1
- package/lib/Table.cjs +1 -1
- package/lib/Table.d.cts +26 -17
- package/lib/Table.d.ts +26 -17
- package/lib/Table.js +1 -1
- package/lib/TableOfContent.cjs +1 -1
- package/lib/TableOfContent.d.cts +26 -17
- package/lib/TableOfContent.d.ts +26 -17
- package/lib/TableOfContent.js +1 -1
- package/lib/TaskList.cjs +1 -1
- package/lib/TaskList.d.cts +26 -17
- package/lib/TaskList.d.ts +26 -17
- package/lib/TaskList.js +1 -1
- package/lib/TextAlign.cjs +1 -1
- package/lib/TextAlign.d.cts +26 -17
- package/lib/TextAlign.d.ts +26 -17
- package/lib/TextAlign.js +1 -1
- package/lib/TextBubble.cjs +1 -1
- package/lib/TextBubble.d.cts +26 -17
- package/lib/TextBubble.d.ts +26 -17
- package/lib/TextBubble.js +1 -1
- package/lib/TextDirection.cjs +1 -1
- package/lib/TextDirection.d.cts +26 -17
- package/lib/TextDirection.d.ts +26 -17
- package/lib/TextDirection.js +1 -1
- package/lib/TextUnderline.cjs +1 -1
- package/lib/TextUnderline.d.cts +26 -17
- package/lib/TextUnderline.d.ts +26 -17
- package/lib/TextUnderline.js +1 -1
- package/lib/TrailingNode.d.cts +26 -17
- package/lib/TrailingNode.d.ts +26 -17
- package/lib/{Twitter-BFwUowi8.cjs → Twitter--OkCPska.cjs} +1 -1
- package/lib/{Twitter-9AKqIK4p.js → Twitter-CXwmqolk.js} +1 -1
- package/lib/Twitter.cjs +1 -1
- package/lib/Twitter.d.cts +26 -17
- package/lib/Twitter.d.ts +26 -17
- package/lib/Twitter.js +1 -1
- package/lib/Video.cjs +1 -1
- package/lib/Video.d.cts +26 -17
- package/lib/Video.d.ts +26 -17
- package/lib/Video.js +1 -1
- package/lib/bubble-extra.cjs +1 -1
- package/lib/bubble-extra.d.cts +26 -17
- package/lib/bubble-extra.d.ts +26 -17
- package/lib/bubble-extra.js +5 -5
- package/lib/index.cjs +1 -1
- package/lib/index.d.cts +26 -17
- package/lib/index.d.ts +26 -17
- package/lib/index.js +2 -2
- package/lib/locale-bundle.d.cts +26 -17
- package/lib/locale-bundle.d.ts +26 -17
- package/lib/{textarea-bND4WL8o.cjs → textarea-DkVc2MIQ.cjs} +1 -1
- package/lib/{textarea-CWt0EMiJ.js → textarea-HW9QlrCS.js} +1 -1
- package/package.json +1 -1
package/lib/SearchAndReplace.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("./index-ByRfqzMr.cjs"),P=require("scroll-into-view-if-needed"),i=require("react/jsx-runtime"),f=require("react"),c=require("./RichTextEditor-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("./index-ByRfqzMr.cjs"),P=require("scroll-into-view-if-needed"),i=require("react/jsx-runtime"),f=require("react"),c=require("./RichTextEditor-DoMu_nCj.cjs"),A=require("./index-D_A0TBRA.cjs");function w({editor:e,...t}){const{t:s}=A.useLocale(),[a,n]=f.useState(-1),[r,l]=f.useState([]),[o,x]=f.useState(""),[u,h]=f.useState(""),[m,C]=f.useState(!1),[p,I]=f.useState(!1);return f.useEffect(()=>{m||(x(""),h(""),n(-1),l([]),e.commands.setSearchTerm(""),e.commands.setReplaceTerm(""))},[e,m]),f.useEffect(()=>{m&&e&&e.commands&&e.commands.setSearchTerm&&e.commands.setSearchTerm(o)},[m,o,e]),f.useEffect(()=>{m&&e&&e.commands&&e.commands.setReplaceTerm&&e.commands.setReplaceTerm(u)},[m,u,e]),f.useEffect(()=>{if(!e)return;const d=e.extensionManager.extensions.find(R=>R.name===j.name);if(!d)return;const T=()=>{if(!m)return;const R=d?d.storage.currentIndex:-1,v=d?d.storage.results:[];n(E=>E!==R?R:E),l(E=>c.deepEqual(E,v)?E:v)};return c.listenEvent(c.EVENTS.SEARCH_REPLCE,T),()=>{d&&c.listenEvent(c.EVENTS.SEARCH_REPLCE,T)}},[m,e]),i.jsxs(c.Popover,{onOpenChange:C,open:m,children:[i.jsx(c.PopoverTrigger,{asChild:!0,disabled:t==null?void 0:t.disabled,children:i.jsx(c.ActionButton,{disabled:t==null?void 0:t.disabled,isActive:t==null?void 0:t.isActive,tooltip:t==null?void 0:t.tooltip,children:i.jsx(c.IconComponent,{name:t==null?void 0:t.icon})})}),i.jsxs(c.PopoverContent,{align:"start",className:"richtext-w-full",hideWhenDetached:!0,side:"bottom",children:[i.jsxs("div",{className:"richtext-mb-[6px] richtext-flex richtext-items-center richtext-justify-between",children:[i.jsx(c.Label,{children:s("editor.search.dialog.text")}),i.jsx("span",{className:"richtext-font-semibold",children:r.length>0?`${a+1}/${r.length}`:"0/0"})]}),i.jsxs("div",{className:"richtext-mb-[10px] richtext-flex richtext-w-full richtext-max-w-sm richtext-items-center richtext-gap-1.5",children:[i.jsx(c.Input,{autoFocus:!0,className:"richtext-w-full",onChange:d=>x(d.target.value),placeholder:"Text",required:!0,type:"text",value:o}),i.jsx(c.Button,{className:"richtext-flex-1",disabled:r.length===0,onClick:e.commands.goToPrevSearchResult,children:i.jsx(c.IconComponent,{name:"ChevronUp"})}),i.jsx(c.Button,{className:"richtext-flex-1",disabled:r.length===0,onClick:e.commands.goToNextSearchResult,children:i.jsx(c.IconComponent,{name:"ChevronDown"})})]}),i.jsx(c.Label,{className:"richtext-mb-[6px]",children:s("editor.replace.dialog.text")}),i.jsx("div",{className:"richtext-mb-[5px] richtext-flex richtext-w-full richtext-max-w-sm richtext-items-center richtext-gap-1.5",children:i.jsx("div",{className:"richtext-relative richtext-w-full richtext-max-w-sm richtext-items-center",children:i.jsx(c.Input,{className:"richtext-w-80",onChange:d=>h(d.target.value),placeholder:"Text",required:!0,type:"text",value:u})})}),i.jsxs("div",{className:"richtext-mb-[10px] richtext-flex richtext-items-center richtext-space-x-2",children:[i.jsx(c.Switch,{checked:p,onCheckedChange:d=>{I(d),e.commands.setCaseSensitive(d)}}),i.jsx(c.Label,{children:s("editor.replace.caseSensitive")})]}),i.jsxs("div",{className:"richtext-flex richtext-items-center richtext-gap-[10px]",children:[i.jsx(c.Button,{className:"richtext-flex-1",disabled:r.length===0,onClick:e.commands.replace,children:s("editor.replace.dialog.text")}),i.jsx(c.Button,{className:"richtext-flex-1",disabled:r.length===0,onClick:e.commands.replaceAll,children:s("editor.replaceAll.dialog.text")})]})]})]})}const S=(e,t)=>t(e.tr);function V(e,t,s){return RegExp(t?e.replace(/[$()*+./?[\\\]^{|}-]/g,String.raw`\$&`):e,s?"gu":"gui")}function L(e,t,s){const a=[];let n=[];const r=[];let l=0;if(!t)return{decorationsToReturn:[],results:[]};e==null||e.descendants((o,x)=>{o.isText?n[l]?n[l]={text:n[l].text+o.text,pos:n[l].pos}:n[l]={text:`${o.text}`,pos:x}:l+=1}),n=n.filter(Boolean);for(const{text:o,pos:x}of n){const u=[...o.matchAll(t)];for(const h of u){if(h[0]==="")break;h.index!==void 0&&r.push({from:x+h.index,to:x+h.index+h[0].length})}}for(const o of r)a.push(g.Decoration.inline(o.from,o.to,{class:s}));return{decorationsToReturn:a,results:r}}function b(e,t,{state:s,dispatch:a}){if(!t[0])return;const{from:r,to:l}=t[0];a&&a(s.tr.insertText(e,r,l))}function y(e,t,s,a){const n=t+1;if(!a[n])return null;const{from:r,to:l}=a[t],o=l-r-e.length+s,{from:x,to:u}=a[n];return a[n]={to:u-o,from:x-o},[o,a]}function D(e,t,{tr:s,dispatch:a}){let n=0,r=t.slice();if(r.length===0)return!1;for(let l=0;l<r.length;l+=1){const{from:o,to:x}=r[l];s.insertText(e,o,x);const u=y(e,l,n,r);u&&(n=u[0],r=u[1])}return a(s),!0}function N({view:e,tr:t,searchResults:s,searchResultCurrentClass:a,gotoIndex:n}){const r=s[n];if(r){const l=t.setMeta("directDecoration",{fromPos:r.from,toPos:r.to,attrs:{class:a}});return e==null||e.dispatch(l),setTimeout(()=>{const o=window.document.querySelector(`.${a}`);o&&P(o,{behavior:"smooth",scrollMode:"if-needed"})},0),!0}return!1}const j=g.Extension.create({name:"search",addOptions(){var e;return{...(e=this.parent)==null?void 0:e.call(this),searchTerm:"",replaceTerm:"",results:[],currentIndex:0,searchResultClass:"search-result",searchResultCurrentClass:"search-result-current",caseSensitive:!1,disableRegex:!1,onChange:()=>{},button:({editor:t,t:s})=>({component:w,componentProps:{action:()=>{},icon:"SearchAndReplace",tooltip:s("editor.searchAndReplace.tooltip"),isActive:()=>!1,disabled:!1,editor:t}})}},addStorage(){return{results:[],currentIndex:-1}},addCommands(){return{setSearchTerm:e=>({state:t,dispatch:s})=>(this.options.searchTerm=e,this.storage.results=[],this.storage.currentIndex=0,c.dispatchEvent(c.EVENTS.SEARCH_REPLCE),S(t,s),!1),setReplaceTerm:e=>({state:t,dispatch:s})=>(this.options.replaceTerm=e,S(t,s),!1),setCaseSensitive:e=>({state:t,dispatch:s})=>(this.options.caseSensitive=e,S(t,s),!1),replace:()=>({state:e,dispatch:t})=>{const{replaceTerm:s}=this.options,{currentIndex:a,results:n}=this.storage,r=n[a];return r?(b(s,[r],{state:e,dispatch:t}),this.storage.results.splice(a,1)):(b(s,n,{state:e,dispatch:t}),this.storage.results.shift()),c.dispatchEvent(c.EVENTS.SEARCH_REPLCE),S(e,t),!1},replaceAll:()=>({state:e,tr:t,dispatch:s})=>{const{replaceTerm:a}=this.options,{results:n}=this.storage;return D(a,n,{tr:t,dispatch:s}),this.storage.currentIndex=-1,this.storage.results=[],c.dispatchEvent(c.EVENTS.SEARCH_REPLCE),S(e,s),!1},goToPrevSearchResult:()=>({view:e,tr:t})=>{const{searchResultCurrentClass:s}=this.options,{currentIndex:a,results:n}=this.storage,r=(a+n.length-1)%n.length;return this.storage.currentIndex=r,c.dispatchEvent(c.EVENTS.SEARCH_REPLCE),N({view:e,tr:t,searchResults:n,searchResultCurrentClass:s,gotoIndex:r})},goToNextSearchResult:()=>({view:e,tr:t})=>{const{searchResultCurrentClass:s}=this.options,{currentIndex:a,results:n}=this.storage,r=(a+1)%n.length;return this.storage.currentIndex=r,this.options.onChange&&this.options.onChange(),c.dispatchEvent(c.EVENTS.SEARCH_REPLCE),N({view:e,tr:t,searchResults:n,searchResultCurrentClass:s,gotoIndex:r})}}},addProseMirrorPlugins(){const e=this;return[new g.Plugin({key:new g.PluginKey("search"),state:{init(){return g.DecorationSet.empty},apply(t){const{doc:s,docChanged:a}=t,{searchTerm:n,searchResultClass:r,searchResultCurrentClass:l,disableRegex:o,caseSensitive:x}=e.options;if(a||n){const{decorationsToReturn:u,results:h}=L(s,V(n,o,x),r);if(e.storage.results=h,e.storage.currentIndex>h.length-1&&(e.storage.currentIndex=0),c.dispatchEvent(c.EVENTS.SEARCH_REPLCE),t.getMeta("directDecoration")){const{fromPos:m,toPos:C,attrs:p}=t.getMeta("directDecoration");u.push(g.Decoration.inline(m,C,p))}else h.length>0&&(u[0]=g.Decoration.inline(h[0].from,h[0].to,{class:l}));return g.DecorationSet.create(s,u)}return g.DecorationSet.empty}},props:{decorations(t){return this.getState(t)}}})]}});exports.SearchAndReplace=j;
|
|
@@ -123,6 +123,16 @@ declare module '@tiptap/core' {
|
|
|
123
123
|
}
|
|
124
124
|
|
|
125
125
|
|
|
126
|
+
declare module '@tiptap/core' {
|
|
127
|
+
interface Commands<ReturnType> {
|
|
128
|
+
drawer: {
|
|
129
|
+
setDrawer: (options: any, replace?: any) => ReturnType;
|
|
130
|
+
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
|
|
126
136
|
declare module '@tiptap/core' {
|
|
127
137
|
interface Commands<ReturnType> {
|
|
128
138
|
emoji: {
|
|
@@ -137,9 +147,8 @@ declare module '@tiptap/core' {
|
|
|
137
147
|
|
|
138
148
|
declare module '@tiptap/core' {
|
|
139
149
|
interface Commands<ReturnType> {
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
150
|
+
excalidraw: {
|
|
151
|
+
setExcalidraw: (attrs?: IExcalidrawAttrs) => ReturnType;
|
|
143
152
|
};
|
|
144
153
|
}
|
|
145
154
|
}
|
|
@@ -147,8 +156,8 @@ declare module '@tiptap/core' {
|
|
|
147
156
|
|
|
148
157
|
declare module '@tiptap/core' {
|
|
149
158
|
interface Commands<ReturnType> {
|
|
150
|
-
|
|
151
|
-
|
|
159
|
+
exportPdf: {
|
|
160
|
+
exportToPdf: () => ReturnType;
|
|
152
161
|
};
|
|
153
162
|
}
|
|
154
163
|
}
|
|
@@ -207,19 +216,19 @@ declare module '@tiptap/core' {
|
|
|
207
216
|
|
|
208
217
|
declare module '@tiptap/core' {
|
|
209
218
|
interface Commands<ReturnType> {
|
|
210
|
-
|
|
219
|
+
imageUpload: {
|
|
211
220
|
/**
|
|
212
|
-
* Add an image
|
|
221
|
+
* Add an image
|
|
213
222
|
*/
|
|
214
|
-
|
|
223
|
+
setImageInline: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
215
224
|
/**
|
|
216
|
-
* Update an image
|
|
225
|
+
* Update an image
|
|
217
226
|
*/
|
|
218
|
-
|
|
227
|
+
updateImage: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
219
228
|
/**
|
|
220
229
|
* Set image alignment
|
|
221
230
|
*/
|
|
222
|
-
|
|
231
|
+
setAlignImage: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
223
232
|
};
|
|
224
233
|
}
|
|
225
234
|
}
|
|
@@ -227,19 +236,19 @@ declare module '@tiptap/core' {
|
|
|
227
236
|
|
|
228
237
|
declare module '@tiptap/core' {
|
|
229
238
|
interface Commands<ReturnType> {
|
|
230
|
-
|
|
239
|
+
imageGifUpload: {
|
|
231
240
|
/**
|
|
232
|
-
* Add an image
|
|
241
|
+
* Add an image gif
|
|
233
242
|
*/
|
|
234
|
-
|
|
243
|
+
setImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
235
244
|
/**
|
|
236
|
-
* Update an image
|
|
245
|
+
* Update an image gif
|
|
237
246
|
*/
|
|
238
|
-
|
|
247
|
+
updateImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
239
248
|
/**
|
|
240
249
|
* Set image alignment
|
|
241
250
|
*/
|
|
242
|
-
|
|
251
|
+
setAlignImageGif: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
243
252
|
};
|
|
244
253
|
}
|
|
245
254
|
}
|
|
@@ -123,6 +123,16 @@ declare module '@tiptap/core' {
|
|
|
123
123
|
}
|
|
124
124
|
|
|
125
125
|
|
|
126
|
+
declare module '@tiptap/core' {
|
|
127
|
+
interface Commands<ReturnType> {
|
|
128
|
+
drawer: {
|
|
129
|
+
setDrawer: (options: any, replace?: any) => ReturnType;
|
|
130
|
+
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
|
|
126
136
|
declare module '@tiptap/core' {
|
|
127
137
|
interface Commands<ReturnType> {
|
|
128
138
|
emoji: {
|
|
@@ -137,9 +147,8 @@ declare module '@tiptap/core' {
|
|
|
137
147
|
|
|
138
148
|
declare module '@tiptap/core' {
|
|
139
149
|
interface Commands<ReturnType> {
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
150
|
+
excalidraw: {
|
|
151
|
+
setExcalidraw: (attrs?: IExcalidrawAttrs) => ReturnType;
|
|
143
152
|
};
|
|
144
153
|
}
|
|
145
154
|
}
|
|
@@ -147,8 +156,8 @@ declare module '@tiptap/core' {
|
|
|
147
156
|
|
|
148
157
|
declare module '@tiptap/core' {
|
|
149
158
|
interface Commands<ReturnType> {
|
|
150
|
-
|
|
151
|
-
|
|
159
|
+
exportPdf: {
|
|
160
|
+
exportToPdf: () => ReturnType;
|
|
152
161
|
};
|
|
153
162
|
}
|
|
154
163
|
}
|
|
@@ -207,19 +216,19 @@ declare module '@tiptap/core' {
|
|
|
207
216
|
|
|
208
217
|
declare module '@tiptap/core' {
|
|
209
218
|
interface Commands<ReturnType> {
|
|
210
|
-
|
|
219
|
+
imageUpload: {
|
|
211
220
|
/**
|
|
212
|
-
* Add an image
|
|
221
|
+
* Add an image
|
|
213
222
|
*/
|
|
214
|
-
|
|
223
|
+
setImageInline: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
215
224
|
/**
|
|
216
|
-
* Update an image
|
|
225
|
+
* Update an image
|
|
217
226
|
*/
|
|
218
|
-
|
|
227
|
+
updateImage: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
219
228
|
/**
|
|
220
229
|
* Set image alignment
|
|
221
230
|
*/
|
|
222
|
-
|
|
231
|
+
setAlignImage: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
223
232
|
};
|
|
224
233
|
}
|
|
225
234
|
}
|
|
@@ -227,19 +236,19 @@ declare module '@tiptap/core' {
|
|
|
227
236
|
|
|
228
237
|
declare module '@tiptap/core' {
|
|
229
238
|
interface Commands<ReturnType> {
|
|
230
|
-
|
|
239
|
+
imageGifUpload: {
|
|
231
240
|
/**
|
|
232
|
-
* Add an image
|
|
241
|
+
* Add an image gif
|
|
233
242
|
*/
|
|
234
|
-
|
|
243
|
+
setImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
235
244
|
/**
|
|
236
|
-
* Update an image
|
|
245
|
+
* Update an image gif
|
|
237
246
|
*/
|
|
238
|
-
|
|
247
|
+
updateImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
239
248
|
/**
|
|
240
249
|
* Set image alignment
|
|
241
250
|
*/
|
|
242
|
-
|
|
251
|
+
setAlignImageGif: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
243
252
|
};
|
|
244
253
|
}
|
|
245
254
|
}
|
package/lib/SearchAndReplace.js
CHANGED
|
@@ -2,7 +2,7 @@ import { E as _, P as M, a as $, b as N, D as P } from "./index-DI9T3iLd.js";
|
|
|
2
2
|
import q from "scroll-into-view-if-needed";
|
|
3
3
|
import { jsxs as f, jsx as o } from "react/jsx-runtime";
|
|
4
4
|
import { useState as g, useEffect as E } from "react";
|
|
5
|
-
import { l as k, E as d, P as B, m as j, A as F, k as A, n as O, L as I, o as y, B as T, S as W, p as K, q as R } from "./RichTextEditor-
|
|
5
|
+
import { l as k, E as d, P as B, m as j, A as F, k as A, n as O, L as I, o as y, B as T, S as W, p as K, q as R } from "./RichTextEditor-BJWhWz4z.js";
|
|
6
6
|
import { u as U } from "./index-CsK90iVd.js";
|
|
7
7
|
function z({ editor: e, ...t }) {
|
|
8
8
|
const { t: s } = U(), [c, r] = g(-1), [n, i] = g([]), [a, u] = g(""), [l, h] = g(""), [x, v] = g(!1), [b, V] = g(!1);
|
package/lib/Selection.d.cts
CHANGED
|
@@ -37,6 +37,16 @@ declare module '@tiptap/core' {
|
|
|
37
37
|
}
|
|
38
38
|
|
|
39
39
|
|
|
40
|
+
declare module '@tiptap/core' {
|
|
41
|
+
interface Commands<ReturnType> {
|
|
42
|
+
drawer: {
|
|
43
|
+
setDrawer: (options: any, replace?: any) => ReturnType;
|
|
44
|
+
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
|
|
40
50
|
declare module '@tiptap/core' {
|
|
41
51
|
interface Commands<ReturnType> {
|
|
42
52
|
emoji: {
|
|
@@ -51,9 +61,8 @@ declare module '@tiptap/core' {
|
|
|
51
61
|
|
|
52
62
|
declare module '@tiptap/core' {
|
|
53
63
|
interface Commands<ReturnType> {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
64
|
+
excalidraw: {
|
|
65
|
+
setExcalidraw: (attrs?: IExcalidrawAttrs) => ReturnType;
|
|
57
66
|
};
|
|
58
67
|
}
|
|
59
68
|
}
|
|
@@ -61,8 +70,8 @@ declare module '@tiptap/core' {
|
|
|
61
70
|
|
|
62
71
|
declare module '@tiptap/core' {
|
|
63
72
|
interface Commands<ReturnType> {
|
|
64
|
-
|
|
65
|
-
|
|
73
|
+
exportPdf: {
|
|
74
|
+
exportToPdf: () => ReturnType;
|
|
66
75
|
};
|
|
67
76
|
}
|
|
68
77
|
}
|
|
@@ -121,19 +130,19 @@ declare module '@tiptap/core' {
|
|
|
121
130
|
|
|
122
131
|
declare module '@tiptap/core' {
|
|
123
132
|
interface Commands<ReturnType> {
|
|
124
|
-
|
|
133
|
+
imageUpload: {
|
|
125
134
|
/**
|
|
126
|
-
* Add an image
|
|
135
|
+
* Add an image
|
|
127
136
|
*/
|
|
128
|
-
|
|
137
|
+
setImageInline: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
129
138
|
/**
|
|
130
|
-
* Update an image
|
|
139
|
+
* Update an image
|
|
131
140
|
*/
|
|
132
|
-
|
|
141
|
+
updateImage: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
133
142
|
/**
|
|
134
143
|
* Set image alignment
|
|
135
144
|
*/
|
|
136
|
-
|
|
145
|
+
setAlignImage: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
137
146
|
};
|
|
138
147
|
}
|
|
139
148
|
}
|
|
@@ -141,19 +150,19 @@ declare module '@tiptap/core' {
|
|
|
141
150
|
|
|
142
151
|
declare module '@tiptap/core' {
|
|
143
152
|
interface Commands<ReturnType> {
|
|
144
|
-
|
|
153
|
+
imageGifUpload: {
|
|
145
154
|
/**
|
|
146
|
-
* Add an image
|
|
155
|
+
* Add an image gif
|
|
147
156
|
*/
|
|
148
|
-
|
|
157
|
+
setImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
149
158
|
/**
|
|
150
|
-
* Update an image
|
|
159
|
+
* Update an image gif
|
|
151
160
|
*/
|
|
152
|
-
|
|
161
|
+
updateImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
153
162
|
/**
|
|
154
163
|
* Set image alignment
|
|
155
164
|
*/
|
|
156
|
-
|
|
165
|
+
setAlignImageGif: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
157
166
|
};
|
|
158
167
|
}
|
|
159
168
|
}
|
package/lib/Selection.d.ts
CHANGED
|
@@ -37,6 +37,16 @@ declare module '@tiptap/core' {
|
|
|
37
37
|
}
|
|
38
38
|
|
|
39
39
|
|
|
40
|
+
declare module '@tiptap/core' {
|
|
41
|
+
interface Commands<ReturnType> {
|
|
42
|
+
drawer: {
|
|
43
|
+
setDrawer: (options: any, replace?: any) => ReturnType;
|
|
44
|
+
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
|
|
40
50
|
declare module '@tiptap/core' {
|
|
41
51
|
interface Commands<ReturnType> {
|
|
42
52
|
emoji: {
|
|
@@ -51,9 +61,8 @@ declare module '@tiptap/core' {
|
|
|
51
61
|
|
|
52
62
|
declare module '@tiptap/core' {
|
|
53
63
|
interface Commands<ReturnType> {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
64
|
+
excalidraw: {
|
|
65
|
+
setExcalidraw: (attrs?: IExcalidrawAttrs) => ReturnType;
|
|
57
66
|
};
|
|
58
67
|
}
|
|
59
68
|
}
|
|
@@ -61,8 +70,8 @@ declare module '@tiptap/core' {
|
|
|
61
70
|
|
|
62
71
|
declare module '@tiptap/core' {
|
|
63
72
|
interface Commands<ReturnType> {
|
|
64
|
-
|
|
65
|
-
|
|
73
|
+
exportPdf: {
|
|
74
|
+
exportToPdf: () => ReturnType;
|
|
66
75
|
};
|
|
67
76
|
}
|
|
68
77
|
}
|
|
@@ -121,19 +130,19 @@ declare module '@tiptap/core' {
|
|
|
121
130
|
|
|
122
131
|
declare module '@tiptap/core' {
|
|
123
132
|
interface Commands<ReturnType> {
|
|
124
|
-
|
|
133
|
+
imageUpload: {
|
|
125
134
|
/**
|
|
126
|
-
* Add an image
|
|
135
|
+
* Add an image
|
|
127
136
|
*/
|
|
128
|
-
|
|
137
|
+
setImageInline: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
129
138
|
/**
|
|
130
|
-
* Update an image
|
|
139
|
+
* Update an image
|
|
131
140
|
*/
|
|
132
|
-
|
|
141
|
+
updateImage: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
133
142
|
/**
|
|
134
143
|
* Set image alignment
|
|
135
144
|
*/
|
|
136
|
-
|
|
145
|
+
setAlignImage: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
137
146
|
};
|
|
138
147
|
}
|
|
139
148
|
}
|
|
@@ -141,19 +150,19 @@ declare module '@tiptap/core' {
|
|
|
141
150
|
|
|
142
151
|
declare module '@tiptap/core' {
|
|
143
152
|
interface Commands<ReturnType> {
|
|
144
|
-
|
|
153
|
+
imageGifUpload: {
|
|
145
154
|
/**
|
|
146
|
-
* Add an image
|
|
155
|
+
* Add an image gif
|
|
147
156
|
*/
|
|
148
|
-
|
|
157
|
+
setImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
149
158
|
/**
|
|
150
|
-
* Update an image
|
|
159
|
+
* Update an image gif
|
|
151
160
|
*/
|
|
152
|
-
|
|
161
|
+
updateImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
153
162
|
/**
|
|
154
163
|
* Set image alignment
|
|
155
164
|
*/
|
|
156
|
-
|
|
165
|
+
setAlignImageGif: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
157
166
|
};
|
|
158
167
|
}
|
|
159
168
|
}
|
package/lib/SlashCommand.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const A=require("./index-ByRfqzMr.cjs"),O=require("./dom-dataset-Byuf1YmW.cjs"),q=require("./index-BI-IcZcN.cjs"),D=require("tippy.js"),f=require("react/jsx-runtime"),x=require("react"),b=require("./RichTextEditor-
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const A=require("./index-ByRfqzMr.cjs"),O=require("./dom-dataset-Byuf1YmW.cjs"),q=require("./index-BI-IcZcN.cjs"),D=require("tippy.js"),f=require("react/jsx-runtime"),x=require("react"),b=require("./RichTextEditor-DoMu_nCj.cjs"),h=require("./index-D_A0TBRA.cjs");function P(i,d){var k,N;const[t,n]=x.useState(0),[e,o]=x.useState(0),r=x.useRef(null),{t:s}=h.useLocale(),u=x.useRef([]);x.useImperativeHandle(d,()=>({onKeyDown:g})),x.useEffect(()=>{if(!r.current)return;const l=e*1e3+t,c=u.current[l];c&&c.scrollIntoView({behavior:"smooth",block:"nearest"})},[t,e]);function g({event:l}){return l.key==="ArrowUp"?(C(),!0):l.key==="ArrowDown"?(R(),!0):l.key==="Enter"?(L(),!0):!1}function C(){var m;if(i.items.length===0)return!1;let l=t-1,c=e;l<0&&(c=e-1,l=((m=i.items[c])==null?void 0:m.commands.length)-1||0),c<0&&(c=i.items.length-1,l=i.items[c].commands.length-1),n(l),o(c)}function R(){if(i.items.length===0)return!1;const l=i.items[e].commands;let c=t+1,m=e;l.length-1<c&&(c=0,m=e+1),i.items.length-1<m&&(m=0),n(c),o(m)}function L(){if(i.items.length===0||e===-1||t===-1)return!1;v(e,t)}function v(l,c){const m=i.items[l].commands[c];i.command(m)}function H(l,c){v(l,c)}function I(l,c,m){u.current[l*1e3+c]=m}return f.jsx("div",{className:"richtext-mb-8 richtext-max-h-[min(80vh,24rem)] richtext-flex-wrap richtext-overflow-auto richtext-rounded-lg !richtext-border !richtext-border-neutral-200 !richtext-bg-white richtext-p-1 !richtext-text-black richtext-shadow-sm dark:!richtext-border-neutral-800 dark:!richtext-bg-black",ref:r,children:(k=i==null?void 0:i.items)!=null&&k.length?f.jsx("div",{className:"richtext-grid richtext-min-w-48 richtext-grid-cols-1 richtext-gap-0.5",children:(N=i==null?void 0:i.items)==null?void 0:N.map((l,c)=>f.jsxs(x.Fragment,{children:[f.jsx("div",{className:"richtext-col-[1/-1] richtext-mx-2 richtext-mt-2 richtext-select-none richtext-text-[0.65rem] richtext-font-semibold richtext-uppercase richtext-tracking-wider !richtext-text-neutral-500 first:richtext-mt-0.5",children:l.title}),l.commands.map((m,y)=>f.jsxs("button",{onClick:()=>H(c,y),ref:S=>I(c,y,S),className:b.cn("richtext-flex richtext-items-center richtext-gap-3 richtext-px-2 richtext-py-1.5 richtext-text-sm !richtext-text-neutral-800 dark:!richtext-text-neutral-200 richtext-text-left richtext-w-full richtext-rounded-sm richtext-outline-none richtext-transition-colors !richtext-bg-transparent hover:!richtext-bg-accent ",{"slash-command-active":e===c&&t===y}),children:[m.iconUrl&&f.jsx("img",{alt:"",className:"richtext-size-6",src:m.iconUrl}),m.iconName&&f.jsx(b.IconComponent,{className:"!richtext-mr-1 !richtext-text-lg",name:m.iconName}),m.label]},`command-${y}`))]},`slash-${l.title}`))}):f.jsx("div",{className:"richtext-p-3",children:f.jsx("span",{className:"richtext-text-xs richtext-text-gray-800 dark:richtext-text-gray-100",children:s("editor.slash.empty")})})})}const $=x.forwardRef(P),j={setOpen:(i,d)=>{b.dispatchEvent(b.EVENTS.UPLOAD_VIDEO(i),d)}};function B(i,d){const t=[{name:"format",title:h.localeActions.t("editor.slash.format"),commands:[]},{name:"insert",title:h.localeActions.t("editor.slash.insert"),commands:[]}];return i.forEach(n=>{n.name.toLowerCase()==="heading"&&n.options.levels.forEach(e=>{t[0].commands.push({name:`heading${e}`,label:h.localeActions.t(`editor.heading.h${e}.tooltip`),aliases:[`h${e}`,"bt",`bt${e}`],iconName:`Heading${e}`,action:({editor:o,range:r})=>{o.chain().focus().deleteRange(r).setHeading({level:e}).run()}})}),n.name.toLowerCase()==="bulletlist"&&t[0].commands.push({name:"bulletList",label:h.localeActions.t("editor.bulletlist.tooltip"),aliases:["ul","yxlb"],iconName:"List",action:({editor:e,range:o})=>{e.chain().focus().deleteRange(o).toggleBulletList().run()}}),n.name.toLowerCase()==="orderedlist"&&t[0].commands.push({name:"numberedList",label:h.localeActions.t("editor.orderedlist.tooltip"),aliases:["ol","yxlb"],iconName:"ListOrdered",action:({editor:e,range:o})=>{e.chain().focus().deleteRange(o).toggleOrderedList().run()}}),n.name.toLowerCase()==="tasklist"&&t[0].commands.push({name:"taskList",label:h.localeActions.t("editor.tasklist.tooltip"),iconName:"ListTodo",description:"Task list with todo items",aliases:["todo"],action:({editor:e,range:o})=>{e.chain().focus().deleteRange(o).toggleTaskList().run()}}),n.name.toLowerCase()==="blockquote"&&t[0].commands.push({name:"blockquote",label:h.localeActions.t("editor.blockquote.tooltip"),description:"插入引入格式",aliases:["yr"],iconName:"TextQuote",action:({editor:e,range:o})=>{e.chain().focus().deleteRange(o).setBlockquote().run()}}),n.name.toLowerCase()==="codeblock"&&t[0].commands.push({name:"codeBlock",label:h.localeActions.t("editor.codeblock.tooltip"),iconName:"Code2",description:"Code block with syntax highlighting",shouldBeHidden:e=>e.isActive("columns"),action:({editor:e,range:o})=>{e.chain().focus().deleteRange(o).setCodeBlock().run()}}),n.name.toLowerCase()===b.Image$1.name&&t[1].commands.push({name:"image",label:h.localeActions.t("editor.image.tooltip"),iconName:"ImageUp",description:"Insert a image",aliases:["image","tp","tupian"],shouldBeHidden:e=>e.isActive("columns"),action:({editor:e,range:o})=>{e.chain().focus().deleteRange(o).run(),b.actionDialogImage.setOpen(e.id,!0)}}),n.name.toLowerCase()===b.Video.name&&t[1].commands.push({name:"video",label:h.localeActions.t("editor.video.tooltip"),iconName:"Video",description:"Insert a video",aliases:["video","sp","shipin"],shouldBeHidden:e=>e.isActive("columns"),action:({editor:e,range:o})=>{e.chain().focus().deleteRange(o).run(),j.setOpen(e.id,!0)}}),n.name.toLowerCase()==="table"&&t[1].commands.push({name:"table",label:h.localeActions.t("editor.table.tooltip"),iconName:"Table",description:"Insert a table",aliases:["table","bg","biaoge","biao"],shouldBeHidden:e=>e.isActive("columns"),action:({editor:e,range:o})=>{e.chain().focus().deleteRange(o).insertTable({rows:3,cols:3,withHeaderRow:!1}).run()}}),n.name.toLowerCase()==="horizontalrule"&&t[1].commands.push({name:"horizontalRule",label:h.localeActions.t("editor.horizontalrule.tooltip"),iconName:"Minus",description:"Insert a horizontal divider",aliases:["hr","fgx","fg"],action:({editor:e,range:o})=>{e.chain().focus().deleteRange(o).setHorizontalRule().run()}}),n.name.toLowerCase()==="columns"&&t[1].commands.push({name:"columns",label:h.localeActions.t("editor.columns.tooltip"),iconName:"Columns2",description:"Add two column content",action:({editor:e})=>{e.chain().focus().insertColumns({cols:2}).run()}}),d==null||d(n,t)}),t}const w="slashCommand";let a;const E=A.Extension.create({name:w,priority:200,onCreate(){a=D("body",{interactive:!0,trigger:"manual",placement:"bottom-start",theme:"slash-command",maxWidth:"16rem",offset:[16,8],popperOptions:{strategy:"fixed",modifiers:[{name:"flip",enabled:!1}]}})},addProseMirrorPlugins(){return[q.Suggestion({editor:this.editor,char:"/",allowSpaces:!0,startOfLine:!0,pluginKey:new A.PluginKey(w),allow:({state:i,range:d})=>{var g,C,R;const t=i.doc.resolve(d.from),n=t.depth===1,e=t.parent.type.name==="paragraph",o=((g=t.parent.textContent)==null?void 0:g.charAt(0))==="/",r=this.editor.isActive("column"),s=(R=t.parent.textContent)==null?void 0:R.slice(Math.max(0,(C=t.parent.textContent)==null?void 0:C.indexOf("/"))),u=!(s!=null&&s.endsWith(" "));return(n&&e&&o||r&&e&&o)&&u},command:({editor:i,range:d,props:t})=>{const{view:n}=i;t.action({editor:i,range:d}),n.focus()},items:({query:i,editor:d})=>B(d.extensionManager.extensions,this.options.renderGroupItem).map(r=>({...r,commands:r.commands.filter(s=>{const u=s.label.toLowerCase().trim(),g=i.toLowerCase().trim();if(s.aliases){const C=s.aliases.map(v=>v.toLowerCase().trim()),R=u.match(g),L=C.some(v=>v.match(g));return R||L}return u.match(g)}).filter(s=>s.shouldBeHidden?!s.shouldBeHidden(this.editor):!0)})).filter(r=>r.commands.length>0).map(r=>({...r,commands:r.commands.map(s=>({...s,isEnabled:!0}))})),render:()=>{let i,d=null;return{onStart:t=>{var o;i=new O.ReactRenderer($,{props:t,editor:t.editor});const{view:n}=t.editor,e=()=>{if(!t.clientRect)return t.editor.storage[w].rect;const r=t.clientRect();if(!r)return t.editor.storage[w].rect;let s=r.y;if(r.top+i.element.offsetHeight+40>window.innerHeight){const u=r.top+i.element.offsetHeight-window.innerHeight+40;s=r.y-u}return new DOMRect(r.x,s,r.width,r.height)};d=()=>{a==null||a[0].setProps({getReferenceClientRect:e})},(o=n.dom.parentElement)==null||o.addEventListener("scroll",d),a==null||a[0].setProps({getReferenceClientRect:e,appendTo:()=>document.body,content:i.element}),a==null||a[0].show()},onUpdate(t){var r;i.updateProps(t);const{view:n}=t.editor,e=()=>{if(!t.clientRect)return t.editor.storage[w].rect;const s=t.clientRect();return s?new DOMRect(s.x,s.y,s.width,s.height):t.editor.storage[w].rect},o=()=>{a==null||a[0].setProps({getReferenceClientRect:e})};(r=n.dom.parentElement)==null||r.addEventListener("scroll",o),t.editor.storage[w].rect=t.clientRect?e():{width:0,height:0,left:0,top:0,right:0,bottom:0},a==null||a[0].setProps({getReferenceClientRect:e})},onKeyDown(t){var n;return t.event.key==="Escape"?(a==null||a[0].hide(),!0):(a!=null&&a[0].state.isShown||a==null||a[0].show(),(n=i.ref)==null?void 0:n.onKeyDown(t))},onExit(t){var n;if(a==null||a[0].hide(),d){const{view:e}=t.editor;(n=e.dom.parentElement)==null||n.removeEventListener("scroll",d)}i.destroy()}}}})]},addStorage(){return{rect:{width:0,height:0,left:0,top:0,right:0,bottom:0}}}});exports.SlashCommand=E;exports.default=E;
|
package/lib/SlashCommand.d.cts
CHANGED
|
@@ -64,6 +64,16 @@ declare module '@tiptap/core' {
|
|
|
64
64
|
}
|
|
65
65
|
|
|
66
66
|
|
|
67
|
+
declare module '@tiptap/core' {
|
|
68
|
+
interface Commands<ReturnType> {
|
|
69
|
+
drawer: {
|
|
70
|
+
setDrawer: (options: any, replace?: any) => ReturnType;
|
|
71
|
+
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
|
|
67
77
|
declare module '@tiptap/core' {
|
|
68
78
|
interface Commands<ReturnType> {
|
|
69
79
|
emoji: {
|
|
@@ -78,9 +88,8 @@ declare module '@tiptap/core' {
|
|
|
78
88
|
|
|
79
89
|
declare module '@tiptap/core' {
|
|
80
90
|
interface Commands<ReturnType> {
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
91
|
+
excalidraw: {
|
|
92
|
+
setExcalidraw: (attrs?: IExcalidrawAttrs) => ReturnType;
|
|
84
93
|
};
|
|
85
94
|
}
|
|
86
95
|
}
|
|
@@ -88,8 +97,8 @@ declare module '@tiptap/core' {
|
|
|
88
97
|
|
|
89
98
|
declare module '@tiptap/core' {
|
|
90
99
|
interface Commands<ReturnType> {
|
|
91
|
-
|
|
92
|
-
|
|
100
|
+
exportPdf: {
|
|
101
|
+
exportToPdf: () => ReturnType;
|
|
93
102
|
};
|
|
94
103
|
}
|
|
95
104
|
}
|
|
@@ -148,19 +157,19 @@ declare module '@tiptap/core' {
|
|
|
148
157
|
|
|
149
158
|
declare module '@tiptap/core' {
|
|
150
159
|
interface Commands<ReturnType> {
|
|
151
|
-
|
|
160
|
+
imageUpload: {
|
|
152
161
|
/**
|
|
153
|
-
* Add an image
|
|
162
|
+
* Add an image
|
|
154
163
|
*/
|
|
155
|
-
|
|
164
|
+
setImageInline: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
156
165
|
/**
|
|
157
|
-
* Update an image
|
|
166
|
+
* Update an image
|
|
158
167
|
*/
|
|
159
|
-
|
|
168
|
+
updateImage: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
160
169
|
/**
|
|
161
170
|
* Set image alignment
|
|
162
171
|
*/
|
|
163
|
-
|
|
172
|
+
setAlignImage: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
164
173
|
};
|
|
165
174
|
}
|
|
166
175
|
}
|
|
@@ -168,19 +177,19 @@ declare module '@tiptap/core' {
|
|
|
168
177
|
|
|
169
178
|
declare module '@tiptap/core' {
|
|
170
179
|
interface Commands<ReturnType> {
|
|
171
|
-
|
|
180
|
+
imageGifUpload: {
|
|
172
181
|
/**
|
|
173
|
-
* Add an image
|
|
182
|
+
* Add an image gif
|
|
174
183
|
*/
|
|
175
|
-
|
|
184
|
+
setImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
176
185
|
/**
|
|
177
|
-
* Update an image
|
|
186
|
+
* Update an image gif
|
|
178
187
|
*/
|
|
179
|
-
|
|
188
|
+
updateImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
180
189
|
/**
|
|
181
190
|
* Set image alignment
|
|
182
191
|
*/
|
|
183
|
-
|
|
192
|
+
setAlignImageGif: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
184
193
|
};
|
|
185
194
|
}
|
|
186
195
|
}
|
package/lib/SlashCommand.d.ts
CHANGED
|
@@ -64,6 +64,16 @@ declare module '@tiptap/core' {
|
|
|
64
64
|
}
|
|
65
65
|
|
|
66
66
|
|
|
67
|
+
declare module '@tiptap/core' {
|
|
68
|
+
interface Commands<ReturnType> {
|
|
69
|
+
drawer: {
|
|
70
|
+
setDrawer: (options: any, replace?: any) => ReturnType;
|
|
71
|
+
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
|
|
67
77
|
declare module '@tiptap/core' {
|
|
68
78
|
interface Commands<ReturnType> {
|
|
69
79
|
emoji: {
|
|
@@ -78,9 +88,8 @@ declare module '@tiptap/core' {
|
|
|
78
88
|
|
|
79
89
|
declare module '@tiptap/core' {
|
|
80
90
|
interface Commands<ReturnType> {
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
setAlignImageDrawer: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
91
|
+
excalidraw: {
|
|
92
|
+
setExcalidraw: (attrs?: IExcalidrawAttrs) => ReturnType;
|
|
84
93
|
};
|
|
85
94
|
}
|
|
86
95
|
}
|
|
@@ -88,8 +97,8 @@ declare module '@tiptap/core' {
|
|
|
88
97
|
|
|
89
98
|
declare module '@tiptap/core' {
|
|
90
99
|
interface Commands<ReturnType> {
|
|
91
|
-
|
|
92
|
-
|
|
100
|
+
exportPdf: {
|
|
101
|
+
exportToPdf: () => ReturnType;
|
|
93
102
|
};
|
|
94
103
|
}
|
|
95
104
|
}
|
|
@@ -148,19 +157,19 @@ declare module '@tiptap/core' {
|
|
|
148
157
|
|
|
149
158
|
declare module '@tiptap/core' {
|
|
150
159
|
interface Commands<ReturnType> {
|
|
151
|
-
|
|
160
|
+
imageUpload: {
|
|
152
161
|
/**
|
|
153
|
-
* Add an image
|
|
162
|
+
* Add an image
|
|
154
163
|
*/
|
|
155
|
-
|
|
164
|
+
setImageInline: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
156
165
|
/**
|
|
157
|
-
* Update an image
|
|
166
|
+
* Update an image
|
|
158
167
|
*/
|
|
159
|
-
|
|
168
|
+
updateImage: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
160
169
|
/**
|
|
161
170
|
* Set image alignment
|
|
162
171
|
*/
|
|
163
|
-
|
|
172
|
+
setAlignImage: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
164
173
|
};
|
|
165
174
|
}
|
|
166
175
|
}
|
|
@@ -168,19 +177,19 @@ declare module '@tiptap/core' {
|
|
|
168
177
|
|
|
169
178
|
declare module '@tiptap/core' {
|
|
170
179
|
interface Commands<ReturnType> {
|
|
171
|
-
|
|
180
|
+
imageGifUpload: {
|
|
172
181
|
/**
|
|
173
|
-
* Add an image
|
|
182
|
+
* Add an image gif
|
|
174
183
|
*/
|
|
175
|
-
|
|
184
|
+
setImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
176
185
|
/**
|
|
177
|
-
* Update an image
|
|
186
|
+
* Update an image gif
|
|
178
187
|
*/
|
|
179
|
-
|
|
188
|
+
updateImageGif: (options: Partial<SetImageAttrsOptions>) => ReturnType;
|
|
180
189
|
/**
|
|
181
190
|
* Set image alignment
|
|
182
191
|
*/
|
|
183
|
-
|
|
192
|
+
setAlignImageGif: (align: 'left' | 'center' | 'right') => ReturnType;
|
|
184
193
|
};
|
|
185
194
|
}
|
|
186
195
|
}
|