@remarkablejames/editor 0.0.5 → 0.0.7
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/README.md +1 -1
- package/lib/ActionMenuButton-D9o3Kwmv.cjs +1 -0
- package/lib/{ActionMenuButton-DBZjUu-F.js → ActionMenuButton-nxV91Fqo.js} +10 -9
- package/lib/Attachment.cjs +19 -1
- package/lib/Attachment.js +270 -7
- package/lib/Blockquote.cjs +2 -2
- package/lib/Blockquote.js +12 -13
- package/lib/Bold.cjs +1 -1
- package/lib/Bold.js +10 -11
- package/lib/BulletList.cjs +1 -1
- package/lib/BulletList.js +8 -9
- package/lib/Callout.cjs +1 -1
- package/lib/Callout.js +45 -41
- package/lib/Clear.cjs +1 -1
- package/lib/Clear.js +14 -13
- package/lib/Code.cjs +1 -1
- package/lib/Code.js +5 -6
- package/lib/CodeBlock.cjs +1 -1
- package/lib/CodeBlock.js +31 -30
- package/lib/CodeView.cjs +1 -1
- package/lib/CodeView.js +8 -9
- package/lib/Color.cjs +1 -1
- package/lib/Color.js +19 -18
- package/lib/Column.cjs +1 -1
- package/lib/Column.js +8 -9
- package/lib/Drawer-Bh-y5bs8.cjs +2 -0
- package/lib/{Drawer-DTCwtJEs.js → Drawer-CF6Z_IA2.js} +24 -18
- package/lib/Drawer.cjs +1 -1
- package/lib/Drawer.js +3 -3
- package/lib/Emoji.cjs +1 -1
- package/lib/Emoji.js +15 -14
- package/lib/Excalidraw.cjs +1 -1
- package/lib/Excalidraw.js +33 -28
- package/lib/ExportPdf.cjs +3 -3
- package/lib/ExportPdf.js +13 -14
- package/lib/ExportWord.cjs +1 -1
- package/lib/ExportWord.js +6 -6
- package/lib/FontFamily.cjs +1 -1
- package/lib/FontFamily.js +6 -7
- package/lib/FontSize.cjs +1 -1
- package/lib/FontSize.js +14 -15
- package/lib/Heading.cjs +1 -1
- package/lib/Heading.js +26 -26
- package/lib/Highlight.cjs +1 -1
- package/lib/Highlight.js +23 -22
- package/lib/History.cjs +1 -1
- package/lib/History.js +11 -11
- package/lib/HorizontalRule.cjs +1 -1
- package/lib/HorizontalRule.js +9 -10
- package/lib/Icon-BvGyfX2j.js +15 -0
- package/lib/Icon-wjwoRc9F.cjs +1 -0
- package/lib/Iframe-BbfZKbPY.cjs +1 -0
- package/lib/{Iframe-D-UYBxiv.js → Iframe-Dfd3LI7b.js} +18 -15
- package/lib/Iframe.cjs +1 -1
- package/lib/Iframe.js +3 -3
- package/lib/Image.cjs +1 -1
- package/lib/Image.js +5 -4
- package/lib/ImageCropper-CY1ETEjC.cjs +10 -0
- package/lib/ImageCropper-DrSdjo9x.js +979 -0
- package/lib/ImageGif.cjs +1 -1
- package/lib/ImageGif.js +80 -77
- package/lib/ImportWord.cjs +1 -1
- package/lib/ImportWord.js +28 -26
- package/lib/{Indent-Bvt-Qwar.js → Indent-CDVF9DWN.js} +30 -31
- package/lib/Indent-Q1VuhSM2.cjs +1 -0
- package/lib/Indent.cjs +1 -1
- package/lib/Indent.js +2 -2
- package/lib/Italic.cjs +1 -1
- package/lib/Italic.js +11 -12
- package/lib/{Katex-CJDtvu-v.js → Katex-DqhWWAA-.js} +22 -19
- package/lib/Katex-K1QU2SB2.cjs +4 -0
- package/lib/Katex.cjs +1 -1
- package/lib/Katex.js +2 -2
- package/lib/LineHeight.cjs +1 -1
- package/lib/LineHeight.js +20 -19
- package/lib/Link.cjs +1 -1
- package/lib/Link.js +2 -2
- package/lib/LinkEditBlock-CBYGLs3J.cjs +5 -0
- package/lib/{LinkEditBlock-Cdqwj_NU.js → LinkEditBlock-xP0pGVhB.js} +24 -19
- package/lib/Mention.js +3 -3
- package/lib/{Mermaid-CnMYVX1P.js → Mermaid-BJ6ryVdY.js} +48 -45
- package/lib/Mermaid-D3_nLeOW.cjs +2 -0
- package/lib/Mermaid.cjs +1 -1
- package/lib/Mermaid.js +2 -2
- package/lib/MoreMark.cjs +1 -1
- package/lib/MoreMark.js +28 -26
- package/lib/OrderedList.cjs +1 -1
- package/lib/OrderedList.js +10 -11
- package/lib/PaywallSeparator.cjs +1 -0
- package/lib/PaywallSeparator.js +140 -0
- package/lib/SearchAndReplace.cjs +1 -1
- package/lib/SearchAndReplace.js +42 -37
- package/lib/SlashCommand.cjs +1 -1
- package/lib/SlashCommand.js +5 -5
- package/lib/SlashCommandNodeView-CUJrDQS7.cjs +1 -0
- package/lib/{SlashCommandNodeView-DcoLvt_6.js → SlashCommandNodeView-DS9FqMiY.js} +80 -62
- package/lib/Strike.cjs +1 -1
- package/lib/Strike.js +11 -12
- package/lib/Table-CV6pUoVf.cjs +5 -0
- package/lib/{Table-Cu12PvQ_.js → Table-CcG-JNtV.js} +46 -46
- package/lib/Table.cjs +1 -1
- package/lib/Table.js +1 -1
- package/lib/TaskList.cjs +1 -1
- package/lib/TaskList.js +11 -12
- package/lib/TextAlign.cjs +1 -1
- package/lib/TextAlign.js +27 -26
- package/lib/TextDirection.cjs +1 -1
- package/lib/TextDirection.js +19 -18
- package/lib/TextUnderline.cjs +1 -1
- package/lib/TextUnderline.js +8 -9
- package/lib/{Twitter-CrX4XY1j.js → Twitter-BIL3o833.js} +22 -18
- package/lib/Twitter-BfSTqPDh.cjs +1 -0
- package/lib/Twitter.cjs +1 -1
- package/lib/Twitter.js +2 -2
- package/lib/Video-DAKr90QL.js +231 -0
- package/lib/Video-HAinT0w6.cjs +1 -0
- package/lib/Video.cjs +1 -1
- package/lib/Video.js +5 -4
- package/lib/bubble.cjs +3 -3
- package/lib/bubble.js +86 -77
- package/lib/button-090-I3tp.js +35 -0
- package/lib/button-B4Sz2ZhW.cjs +1 -0
- package/lib/checkbox-BCPsu7yR.cjs +1 -0
- package/lib/checkbox-DiXWHAI0.js +29 -0
- package/lib/{clsx-BUPZHhq3.js → clsx-m_C5j3RU.js} +24 -24
- package/lib/components/RichTextProvider.d.ts +1 -1
- package/lib/dialog-C8J59d2J.cjs +1 -0
- package/lib/dialog-bDkDW-C_.js +95 -0
- package/lib/dom-dataset-BqoJhJXt.cjs +1 -0
- package/lib/dom-dataset-CIEeltF6.js +47 -0
- package/lib/{dropdown-menu-CVwXaR3Z.js → dropdown-menu-DWt_xj4h.js} +1 -1
- package/lib/{dropdown-menu-XIrQk3jr.cjs → dropdown-menu-tUP872Zv.cjs} +1 -1
- package/lib/events.constant-Bke62qxm.cjs +1 -0
- package/lib/events.constant-CSWD3-ho.js +72 -0
- package/lib/extensions/PaywallSeparator/PaywallSeparator.d.ts +35 -0
- package/lib/extensions/PaywallSeparator/components/PaywallIcon.d.ts +2 -0
- package/lib/extensions/PaywallSeparator/components/PaywallSeparatorView.d.ts +17 -0
- package/lib/extensions/PaywallSeparator/components/RichTextPaywallSeparator.d.ts +1 -0
- package/lib/extensions/PaywallSeparator/components/index.d.ts +2 -0
- package/lib/extensions/PaywallSeparator/index.d.ts +1 -0
- package/lib/file-i7e4nQY2.cjs +1 -0
- package/lib/file-jDdkhyj7.js +43 -0
- package/lib/{index-RkKGy5oa.js → index-B3Ijnbxs.js} +1 -1
- package/lib/index-BXh8X1ch.cjs +1 -0
- package/lib/{index-Dl3OjzmR.js → index-C1KQsOcg.js} +1 -1
- package/lib/{index-D4M4hrH4.js → index-C8FjP66D.js} +1 -1
- package/lib/index-jMN4V2hr.js +2763 -0
- package/lib/{index-DZj2z9_1.js → index-s3l5RdyW.js} +1 -1
- package/lib/index.cjs +4 -4
- package/lib/index.js +464 -149
- package/lib/input-C_J-pfTx.js +21 -0
- package/lib/input-DwLo4r7V.cjs +1 -0
- package/lib/isNumber-BTYSVlKo.cjs +1 -0
- package/lib/isNumber-WaBzl_0s.js +15 -0
- package/lib/label-BgIVynq3.cjs +1 -0
- package/lib/label-ClsOg9Hr.js +11 -0
- package/lib/{popover-DDT8YRht.js → popover-BC7FRr8B.js} +1 -1
- package/lib/{popover-0syCfWYi.cjs → popover-C3A6zzNV.cjs} +1 -1
- package/lib/{renderNodeView-dj6AaFSX.js → renderNodeView-C_hPIdEs.js} +2 -2
- package/lib/{select-DTNz0ZeE.cjs → select-B8HIWDXf.cjs} +1 -1
- package/lib/{select-D9wQw2qB.js → select-DSKqhVGR.js} +1 -1
- package/lib/{separator-DRGTEiX4.js → separator-BJWSNjvr.js} +13 -12
- package/lib/separator-D6ruF682.cjs +1 -0
- package/lib/style.css +1 -1
- package/lib/tabs-D1J1iB7B.js +46 -0
- package/lib/tabs-IEbMQmNX.cjs +1 -0
- package/lib/{textarea-DfVzbMr5.js → textarea-Ch5w3PiI.js} +1 -1
- package/lib/{textarea-DpkwluT0.cjs → textarea-CtVdqwSM.cjs} +1 -1
- package/lib/theme.cjs +1 -1
- package/lib/theme.js +18 -18
- package/lib/throttle-CRNq0z-O.js +249 -0
- package/lib/throttle-gTTvqDTW.cjs +1 -0
- package/lib/toggle-C9tcMm1r.cjs +1 -0
- package/lib/toggle-CaSwYCk4.js +89 -0
- package/lib/types.d.ts +5 -5
- package/lib/{updatePosition-C294Pixi.js → updatePosition-DvfTZHcH.js} +2 -2
- package/lib/use-toast-C6zPo25l.cjs +1 -0
- package/lib/use-toast-CEOqhXfx.js +97 -0
- package/lib/useButtonProps-D-ruygH7.js +165 -0
- package/lib/useButtonProps-D9ndBdmA.cjs +1 -0
- package/package.json +34 -32
- package/lib/ActionMenuButton-C6jGtl3k.cjs +0 -1
- package/lib/Drawer-B031ezmA.cjs +0 -2
- package/lib/Iframe-BUK2pkOL.cjs +0 -1
- package/lib/Indent-_y6N8MIQ.cjs +0 -1
- package/lib/Katex-bJXkt-VP.cjs +0 -4
- package/lib/LinkEditBlock-ewTApx0K.cjs +0 -5
- package/lib/Mermaid-Dwz9o-yM.cjs +0 -2
- package/lib/SlashCommandNodeView-BMgQJ4xT.cjs +0 -1
- package/lib/Table-B8CHl8jK.cjs +0 -5
- package/lib/Twitter-6HYP_upt.cjs +0 -1
- package/lib/index-B0d-u29p.js +0 -5425
- package/lib/index-De9MZVWQ.cjs +0 -28
- package/lib/separator-D8lOAf8f.cjs +0 -1
package/lib/MoreMark.js
CHANGED
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
import { M as h, m, E as b } from "./clsx-
|
|
2
|
-
import { jsx as e, Fragment as
|
|
3
|
-
import { useMemo as
|
|
4
|
-
import {
|
|
5
|
-
import "./
|
|
6
|
-
import { D as
|
|
1
|
+
import { M as h, m, E as b } from "./clsx-m_C5j3RU.js";
|
|
2
|
+
import { jsx as e, Fragment as f, jsxs as d } from "react/jsx-runtime";
|
|
3
|
+
import { useMemo as M } from "react";
|
|
4
|
+
import { A as x } from "./toggle-CaSwYCk4.js";
|
|
5
|
+
import { u as A, d as S, g as k } from "./useButtonProps-D-ruygH7.js";
|
|
6
|
+
import { D as v, a as y, b as T, c as K } from "./dropdown-menu-DWt_xj4h.js";
|
|
7
|
+
import { M as w } from "./index-jMN4V2hr.js";
|
|
8
|
+
import { I as C } from "./Icon-BvGyfX2j.js";
|
|
7
9
|
var H = h.create({
|
|
8
10
|
name: "subscript",
|
|
9
11
|
addOptions() {
|
|
@@ -75,39 +77,39 @@ var H = h.create({
|
|
|
75
77
|
};
|
|
76
78
|
}
|
|
77
79
|
});
|
|
78
|
-
function
|
|
79
|
-
const t =
|
|
80
|
+
function R() {
|
|
81
|
+
const t = A(D.name), {
|
|
80
82
|
icon: s = void 0,
|
|
81
|
-
tooltip:
|
|
83
|
+
tooltip: o = void 0,
|
|
82
84
|
items: i = [],
|
|
83
85
|
isActive: a = void 0
|
|
84
|
-
} = (t == null ? void 0 : t.componentProps) ?? {}, { disabled: c, dataState:
|
|
85
|
-
return t ? /* @__PURE__ */ d(
|
|
86
|
-
/* @__PURE__ */ e(
|
|
87
|
-
|
|
86
|
+
} = (t == null ? void 0 : t.componentProps) ?? {}, { disabled: c, dataState: n } = S(a), p = M(() => (n == null ? void 0 : n.title) || "", [n]);
|
|
87
|
+
return t ? /* @__PURE__ */ d(v, { children: [
|
|
88
|
+
/* @__PURE__ */ e(y, { asChild: !0, disabled: c, children: /* @__PURE__ */ e(
|
|
89
|
+
x,
|
|
88
90
|
{
|
|
89
91
|
customClass: "!richtext-w-12 richtext-h-12",
|
|
90
92
|
disabled: c,
|
|
91
93
|
icon: s,
|
|
92
|
-
tooltip:
|
|
93
|
-
children: /* @__PURE__ */ e(
|
|
94
|
+
tooltip: o,
|
|
95
|
+
children: /* @__PURE__ */ e(w, { className: "richtext-size-3 richtext-text-gray-500" })
|
|
94
96
|
}
|
|
95
97
|
) }),
|
|
96
|
-
/* @__PURE__ */ e(
|
|
97
|
-
|
|
98
|
+
/* @__PURE__ */ e(T, { className: "w-full", children: i == null ? void 0 : i.map((r, u) => /* @__PURE__ */ d(
|
|
99
|
+
K,
|
|
98
100
|
{
|
|
99
101
|
checked: p === r.title,
|
|
100
102
|
className: "richtext-flex richtext-items-center richtext-gap-3",
|
|
101
103
|
onClick: r.action,
|
|
102
104
|
children: [
|
|
103
|
-
/* @__PURE__ */ e(
|
|
105
|
+
/* @__PURE__ */ e(C, { name: r == null ? void 0 : r.icon }),
|
|
104
106
|
/* @__PURE__ */ e("span", { className: "richtext-ml-1", children: r.title }),
|
|
105
|
-
!!(r != null && r.shortcutKeys) && /* @__PURE__ */ e("span", { className: "richtext-ml-auto richtext-text-xs richtext-tracking-widest richtext-opacity-60", children:
|
|
107
|
+
!!(r != null && r.shortcutKeys) && /* @__PURE__ */ e("span", { className: "richtext-ml-auto richtext-text-xs richtext-tracking-widest richtext-opacity-60", children: k(r.shortcutKeys) })
|
|
106
108
|
]
|
|
107
109
|
},
|
|
108
110
|
`more-mark-${u}`
|
|
109
111
|
)) })
|
|
110
|
-
] }) : /* @__PURE__ */ e(
|
|
112
|
+
] }) : /* @__PURE__ */ e(f, {});
|
|
111
113
|
}
|
|
112
114
|
const D = /* @__PURE__ */ b.create({
|
|
113
115
|
name: "moreMark",
|
|
@@ -116,24 +118,24 @@ const D = /* @__PURE__ */ b.create({
|
|
|
116
118
|
var t;
|
|
117
119
|
return {
|
|
118
120
|
...(t = this.parent) == null ? void 0 : t.call(this),
|
|
119
|
-
button({ editor: s, extension:
|
|
121
|
+
button({ editor: s, extension: o, t: i }) {
|
|
120
122
|
var u, l;
|
|
121
|
-
const a =
|
|
123
|
+
const a = o.options.subscript, c = o.options.superscript, n = {
|
|
122
124
|
action: () => s.commands.toggleSubscript(),
|
|
123
125
|
isActive: () => s.isActive("subscript") || !1,
|
|
124
126
|
disabled: !s.can().toggleSubscript(),
|
|
125
127
|
icon: "Subscript",
|
|
126
128
|
title: i("editor.subscript.tooltip"),
|
|
127
|
-
shortcutKeys: ((u =
|
|
129
|
+
shortcutKeys: ((u = o.options.shortcutKeys) == null ? void 0 : u[0]) ?? ["mod", "."]
|
|
128
130
|
}, p = {
|
|
129
131
|
action: () => s.commands.toggleSuperscript(),
|
|
130
132
|
isActive: () => s.isActive("superscript") || !1,
|
|
131
133
|
disabled: !s.can().toggleSuperscript(),
|
|
132
134
|
icon: "Superscript",
|
|
133
135
|
title: i("editor.superscript.tooltip"),
|
|
134
|
-
shortcutKeys: ((l =
|
|
136
|
+
shortcutKeys: ((l = o.options.shortcutKeys) == null ? void 0 : l[1]) ?? ["mod", ","]
|
|
135
137
|
}, r = [];
|
|
136
|
-
return a !== !1 && r.push(
|
|
138
|
+
return a !== !1 && r.push(n), c !== !1 && r.push(p), {
|
|
137
139
|
// component: ActionMoreButton,
|
|
138
140
|
componentProps: {
|
|
139
141
|
icon: "Type",
|
|
@@ -153,5 +155,5 @@ const D = /* @__PURE__ */ b.create({
|
|
|
153
155
|
});
|
|
154
156
|
export {
|
|
155
157
|
D as MoreMark,
|
|
156
|
-
|
|
158
|
+
R as RichTextMoreMark
|
|
157
159
|
};
|
package/lib/OrderedList.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const O=require("./index-BCzvbrf5.cjs"),s=require("react/jsx-runtime"),g=require("./toggle-C9tcMm1r.cjs"),d=require("./useButtonProps-D9ndBdmA.cjs");function m(){const t=d.useButtonProps(c.name),{icon:e=void 0,tooltip:o=void 0,shortcutKeys:i=void 0,tooltipOptions:u={},action:r=void 0,isActive:a=void 0}=(t==null?void 0:t.componentProps)??{},{dataState:p,disabled:n,update:l}=d.useToggleActive(a),v=()=>{n||r&&(r(),l())};return t?s.jsx(g.ActionButton,{action:v,dataState:p,disabled:n,icon:e,shortcutKeys:i,tooltip:o,tooltipOptions:u}):s.jsx(s.Fragment,{})}const c=O.OrderedList.extend({addOptions(){var t;return{...(t=this.parent)==null?void 0:t.call(this),button:({editor:e,t:o,extension:i})=>({componentProps:{action:()=>e.commands.toggleOrderedList(),isActive:()=>e.isActive("orderedList"),disabled:!1,icon:"ListOrdered",shortcutKeys:i.options.shortcutKeys??["mod","shift","7"],tooltip:o("editor.orderedlist.tooltip")}})}}});exports.OrderedList=c;exports.RichTextOrderedList=m;
|
package/lib/OrderedList.js
CHANGED
|
@@ -1,21 +1,20 @@
|
|
|
1
|
-
import { O as u } from "./index-
|
|
2
|
-
import { jsx as n, Fragment as
|
|
3
|
-
import {
|
|
4
|
-
import "
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const t = f(A.name), {
|
|
1
|
+
import { O as u } from "./index-s3l5RdyW.js";
|
|
2
|
+
import { jsx as n, Fragment as f } from "react/jsx-runtime";
|
|
3
|
+
import { A as l } from "./toggle-CaSwYCk4.js";
|
|
4
|
+
import { u as v, c as O } from "./useButtonProps-D-ruygH7.js";
|
|
5
|
+
function y() {
|
|
6
|
+
const t = v(A.name), {
|
|
8
7
|
icon: o = void 0,
|
|
9
8
|
tooltip: i = void 0,
|
|
10
9
|
shortcutKeys: e = void 0,
|
|
11
10
|
tooltipOptions: d = {},
|
|
12
11
|
action: s = void 0,
|
|
13
12
|
isActive: c = void 0
|
|
14
|
-
} = (t == null ? void 0 : t.componentProps) ?? {}, { dataState: a, disabled: r, update: p } =
|
|
13
|
+
} = (t == null ? void 0 : t.componentProps) ?? {}, { dataState: a, disabled: r, update: p } = O(c), m = () => {
|
|
15
14
|
r || s && (s(), p());
|
|
16
15
|
};
|
|
17
16
|
return t ? /* @__PURE__ */ n(
|
|
18
|
-
|
|
17
|
+
l,
|
|
19
18
|
{
|
|
20
19
|
action: m,
|
|
21
20
|
dataState: a,
|
|
@@ -25,7 +24,7 @@ function K() {
|
|
|
25
24
|
tooltip: i,
|
|
26
25
|
tooltipOptions: d
|
|
27
26
|
}
|
|
28
|
-
) : /* @__PURE__ */ n(
|
|
27
|
+
) : /* @__PURE__ */ n(f, {});
|
|
29
28
|
}
|
|
30
29
|
const A = /* @__PURE__ */ u.extend({
|
|
31
30
|
//@ts-expect-error
|
|
@@ -48,5 +47,5 @@ const A = /* @__PURE__ */ u.extend({
|
|
|
48
47
|
});
|
|
49
48
|
export {
|
|
50
49
|
A as OrderedList,
|
|
51
|
-
|
|
50
|
+
y as RichTextOrderedList
|
|
52
51
|
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("react/jsx-runtime"),c=require("./toggle-C9tcMm1r.cjs"),a=require("./clsx-CXbNJWDD.cjs"),m=require("./use-toast-C6zPo25l.cjs"),d=require("./useButtonProps-D9ndBdmA.cjs");function w(){const e=d.useButtonProps(p.name),{icon:i=void 0,tooltip:s=void 0,shortcutKeys:n=void 0,tooltipOptions:r={},action:o=void 0,isActive:u=void 0}=(e==null?void 0:e.componentProps)??{},{dataState:y,disabled:l,update:x}=d.useToggleActive(u),h=()=>{l||o&&(o(),x())};return e?t.jsx(c.ActionButton,{action:h,dataState:y,disabled:l,icon:i,shortcutKeys:n,tooltip:s,tooltipOptions:r}):t.jsx(t.Fragment,{})}const b=({editor:e})=>e.isEditable?t.jsxs(a.NodeViewWrapper,{as:"div","data-type":"paywallSeparator",className:"richtext-relative richtext-flex richtext-items-center richtext-select-none richtext-my-4",children:[t.jsx("div",{className:"richtext-absolute richtext-inset-x-0",style:{height:"2px",backgroundImage:"linear-gradient(90deg, #fdba74, #f97316, #fdba74)"}}),t.jsx("div",{className:"richtext-relative richtext-mx-auto",children:t.jsx("div",{className:"richtext-rounded-sm richtext-px-3 richtext-py-1 richtext-text-xs richtext-font-semibold richtext-text-orange-700 richtext-shadow-sm",style:{background:"rgba(255, 255, 255, 0.95)",backdropFilter:"blur(4px)",border:"1px solid #d1d5db",outline:"1px solid #f3f4f6"},children:"🔒 Paywall boundary — readers without access will not see anything below this line"})})]}):t.jsx(a.NodeViewWrapper,{as:"div","data-type":"paywallSeparator",style:{display:"none"}}),p=a.Node3.create({name:"paywallSeparator",addOptions(){return{HTMLAttributes:{},divider:!1,spacer:!1,toolbar:!0,button:({editor:e})=>({component:c.ActionButton,componentProps:{action:()=>e.commands.insertPaywall(),disabled:!e.can().insertPaywall(),icon:"PaywallIcon",shortcutKeys:["mod","alt","P"],tooltip:"Insert paywall separator"}})}},group:"block",selectable:!0,atom:!0,draggable:!0,parseHTML(){return[{tag:'div[data-type="paywallSeparator"]'}]},renderHTML({HTMLAttributes:e}){return["div",a.mergeAttributes(this.options.HTMLAttributes,e,{"data-type":"paywallSeparator"}),["hr"]]},addNodeView(){return a.ReactNodeViewRenderer(b)},addCommands(){return{insertPaywall:()=>({commands:e,state:i,dispatch:s})=>{const{doc:n}=i;let r=!1;return n.descendants(o=>{if(o.type.name==="paywallSeparator")return r=!0,!1}),r?(s!==void 0&&m.toast({title:"Paywall already added",description:"Only one paywall separator is allowed per document. Remove the existing one before adding another.",variant:"destructive",duration:4e3}),!1):e.insertContent({type:this.name})}}},addKeyboardShortcuts(){return{"Mod-Alt-p":()=>this.editor.commands.insertPaywall()}}});exports.PaywallSeparator=p;exports.RichTextPaywallSeparator=w;
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { jsx as e, Fragment as y, jsxs as h } from "react/jsx-runtime";
|
|
2
|
+
import { A as d } from "./toggle-CaSwYCk4.js";
|
|
3
|
+
import { h as l, N as x, k as w, m as f } from "./clsx-m_C5j3RU.js";
|
|
4
|
+
import { t as b } from "./use-toast-CEOqhXfx.js";
|
|
5
|
+
import { u as v, c as g } from "./useButtonProps-D-ruygH7.js";
|
|
6
|
+
function H() {
|
|
7
|
+
const t = v(S.name), {
|
|
8
|
+
icon: o = void 0,
|
|
9
|
+
tooltip: i = void 0,
|
|
10
|
+
shortcutKeys: s = void 0,
|
|
11
|
+
tooltipOptions: a = {},
|
|
12
|
+
action: r = void 0,
|
|
13
|
+
isActive: c = void 0
|
|
14
|
+
} = (t == null ? void 0 : t.componentProps) ?? {}, { dataState: p, disabled: n, update: u } = g(c), m = () => {
|
|
15
|
+
n || r && (r(), u());
|
|
16
|
+
};
|
|
17
|
+
return t ? /* @__PURE__ */ e(
|
|
18
|
+
d,
|
|
19
|
+
{
|
|
20
|
+
action: m,
|
|
21
|
+
dataState: p,
|
|
22
|
+
disabled: n,
|
|
23
|
+
icon: o,
|
|
24
|
+
shortcutKeys: s,
|
|
25
|
+
tooltip: i,
|
|
26
|
+
tooltipOptions: a
|
|
27
|
+
}
|
|
28
|
+
) : /* @__PURE__ */ e(y, {});
|
|
29
|
+
}
|
|
30
|
+
const P = ({ editor: t }) => t.isEditable ? /* @__PURE__ */ h(
|
|
31
|
+
l,
|
|
32
|
+
{
|
|
33
|
+
as: "div",
|
|
34
|
+
"data-type": "paywallSeparator",
|
|
35
|
+
className: "richtext-relative richtext-flex richtext-items-center richtext-select-none richtext-my-4",
|
|
36
|
+
children: [
|
|
37
|
+
/* @__PURE__ */ e(
|
|
38
|
+
"div",
|
|
39
|
+
{
|
|
40
|
+
className: "richtext-absolute richtext-inset-x-0",
|
|
41
|
+
style: {
|
|
42
|
+
height: "2px",
|
|
43
|
+
backgroundImage: "linear-gradient(90deg, #fdba74, #f97316, #fdba74)"
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
),
|
|
47
|
+
/* @__PURE__ */ e("div", { className: "richtext-relative richtext-mx-auto", children: /* @__PURE__ */ e(
|
|
48
|
+
"div",
|
|
49
|
+
{
|
|
50
|
+
className: "richtext-rounded-sm richtext-px-3 richtext-py-1 richtext-text-xs richtext-font-semibold richtext-text-orange-700 richtext-shadow-sm",
|
|
51
|
+
style: {
|
|
52
|
+
background: "rgba(255, 255, 255, 0.95)",
|
|
53
|
+
backdropFilter: "blur(4px)",
|
|
54
|
+
border: "1px solid #d1d5db",
|
|
55
|
+
outline: "1px solid #f3f4f6"
|
|
56
|
+
},
|
|
57
|
+
children: "🔒 Paywall boundary — readers without access will not see anything below this line"
|
|
58
|
+
}
|
|
59
|
+
) })
|
|
60
|
+
]
|
|
61
|
+
}
|
|
62
|
+
) : /* @__PURE__ */ e(
|
|
63
|
+
l,
|
|
64
|
+
{
|
|
65
|
+
as: "div",
|
|
66
|
+
"data-type": "paywallSeparator",
|
|
67
|
+
style: { display: "none" }
|
|
68
|
+
}
|
|
69
|
+
), S = /* @__PURE__ */ x.create({
|
|
70
|
+
name: "paywallSeparator",
|
|
71
|
+
addOptions() {
|
|
72
|
+
return {
|
|
73
|
+
HTMLAttributes: {},
|
|
74
|
+
divider: !1,
|
|
75
|
+
spacer: !1,
|
|
76
|
+
toolbar: !0,
|
|
77
|
+
button: ({ editor: t }) => ({
|
|
78
|
+
component: d,
|
|
79
|
+
componentProps: {
|
|
80
|
+
action: () => t.commands.insertPaywall(),
|
|
81
|
+
disabled: !t.can().insertPaywall(),
|
|
82
|
+
icon: "PaywallIcon",
|
|
83
|
+
shortcutKeys: ["mod", "alt", "P"],
|
|
84
|
+
tooltip: "Insert paywall separator"
|
|
85
|
+
}
|
|
86
|
+
})
|
|
87
|
+
};
|
|
88
|
+
},
|
|
89
|
+
group: "block",
|
|
90
|
+
selectable: !0,
|
|
91
|
+
atom: !0,
|
|
92
|
+
draggable: !0,
|
|
93
|
+
parseHTML() {
|
|
94
|
+
return [
|
|
95
|
+
{
|
|
96
|
+
tag: 'div[data-type="paywallSeparator"]'
|
|
97
|
+
}
|
|
98
|
+
];
|
|
99
|
+
},
|
|
100
|
+
renderHTML({ HTMLAttributes: t }) {
|
|
101
|
+
return [
|
|
102
|
+
"div",
|
|
103
|
+
f(this.options.HTMLAttributes, t, {
|
|
104
|
+
"data-type": "paywallSeparator"
|
|
105
|
+
}),
|
|
106
|
+
["hr"]
|
|
107
|
+
];
|
|
108
|
+
},
|
|
109
|
+
addNodeView() {
|
|
110
|
+
return w(P);
|
|
111
|
+
},
|
|
112
|
+
addCommands() {
|
|
113
|
+
return {
|
|
114
|
+
insertPaywall: () => ({ commands: t, state: o, dispatch: i }) => {
|
|
115
|
+
const { doc: s } = o;
|
|
116
|
+
let a = !1;
|
|
117
|
+
return s.descendants((r) => {
|
|
118
|
+
if (r.type.name === "paywallSeparator")
|
|
119
|
+
return a = !0, !1;
|
|
120
|
+
}), a ? (i !== void 0 && b({
|
|
121
|
+
title: "Paywall already added",
|
|
122
|
+
description: "Only one paywall separator is allowed per document. Remove the existing one before adding another.",
|
|
123
|
+
variant: "destructive",
|
|
124
|
+
duration: 4e3
|
|
125
|
+
}), !1) : t.insertContent({
|
|
126
|
+
type: this.name
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
};
|
|
130
|
+
},
|
|
131
|
+
addKeyboardShortcuts() {
|
|
132
|
+
return {
|
|
133
|
+
"Mod-Alt-p": () => this.editor.commands.insertPaywall()
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
export {
|
|
138
|
+
S as PaywallSeparator,
|
|
139
|
+
H as RichTextPaywallSeparator
|
|
140
|
+
};
|
package/lib/SearchAndReplace.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const Y=require("./clsx-CXbNJWDD.cjs"),F=require("@tiptap/pm/state"),b=require("@tiptap/pm/view"),a=require("react/jsx-runtime"),f=require("react"),Z=require("./toggle-C9tcMm1r.cjs"),k=require("./useButtonProps-D9ndBdmA.cjs"),_=require("./index-DgOXAdKt.cjs"),B=require("./popover-C3A6zzNV.cjs"),E=require("./label-BgIVynq3.cjs"),M=require("./input-DwLo4r7V.cjs"),j=require("./button-B4Sz2ZhW.cjs"),V=require("./Icon-wjwoRc9F.cjs"),ee=require("./checkbox-BCPsu7yR.cjs");function te(){const{t}=_.useLocale(),e=k.useEditorInstance(),s=k.useButtonProps(W.name),{icon:n=void 0,tooltip:u=void 0,shortcutKeys:o=void 0,tooltipOptions:c={},action:x=void 0,isActive:h=void 0}=(s==null?void 0:s.componentProps)??{},{disabled:i}=k.useActive(h),[g,d]=f.useState(!1),[p,A]=f.useState(""),[T,N]=f.useState(""),[I,H]=f.useState(!1),[U,L]=f.useState(""),w=()=>{var r,l,R,m;L(`${((l=(r=e==null?void 0:e.storage)==null?void 0:r.searchAndReplace)==null?void 0:l.resultIndex)+1}/${(m=(R=e==null?void 0:e.storage)==null?void 0:R.searchAndReplace)==null?void 0:m.results.length}`)};f.useEffect(()=>{e&&w()},[e]);const z=()=>{i||x&&x()},y=(r=!1)=>{var l,R,m,v,S,D,q,O;e&&(r&&((R=(l=e==null?void 0:e.commands)==null?void 0:l.resetIndex)==null||R.call(l)),(v=(m=e==null?void 0:e.commands)==null?void 0:m.setSearchTerm)==null||v.call(m,p),(D=(S=e==null?void 0:e.commands)==null?void 0:S.setReplaceTerm)==null||D.call(S,T),(O=(q=e==null?void 0:e.commands)==null?void 0:q.setCaseSensitive)==null||O.call(q,I),w())},P=()=>{var v,S;if(!e)return;const{results:r,resultIndex:l}=e.storage.searchAndReplace,R=r[l];if(!R)return;(S=(v=e==null?void 0:e.commands)==null?void 0:v.setTextSelection)==null||S.call(v,R);const{node:m}=e.view.domAtPos(e.state.selection.anchor);m instanceof HTMLElement&&m.scrollIntoView({behavior:"smooth",block:"center"}),w()};f.useEffect(()=>{p.trim()||$(),p.trim()&&y(!0)},[p]),f.useEffect(()=>{T.trim()&&y()},[T]),f.useEffect(()=>{y(!0)},[I]);const G=()=>{var r,l;(l=(r=e==null?void 0:e.commands)==null?void 0:r.replace)==null||l.call(r),P()},J=()=>{var r,l;(l=(r=e==null?void 0:e.commands)==null?void 0:r.nextSearchResult)==null||l.call(r),P()},Q=()=>{var r,l;(l=(r=e==null?void 0:e.commands)==null?void 0:r.previousSearchResult)==null||l.call(r),P()},$=()=>{var r,l;A(""),N(""),(l=(r=e==null?void 0:e.commands)==null?void 0:r.resetIndex)==null||l.call(r),w()},X=()=>{var r,l;(l=(r=e==null?void 0:e.commands)==null?void 0:r.replaceAll)==null||l.call(r),L("0/0")};return s?a.jsxs(B.Popover,{onOpenChange:d,open:g,children:[a.jsx(B.PopoverTrigger,{asChild:!0,disabled:i,children:a.jsx(Z.ActionButton,{action:z,disabled:i,icon:n,shortcutKeys:o,tooltip:u,tooltipOptions:c})}),a.jsxs(B.PopoverContent,{align:"start",className:"richtext-w-full",hideWhenDetached:!0,side:"bottom",children:[a.jsxs("div",{className:"richtext-mb-[6px] richtext-flex richtext-items-center richtext-justify-between",children:[a.jsx(E.Label,{children:t("editor.search.dialog.text")}),a.jsx("span",{className:"richtext-font-semibold",children:U})]}),a.jsxs("div",{className:"richtext-mb-[10px] richtext-flex richtext-w-full richtext-max-w-sm richtext-items-center richtext-gap-1.5",children:[a.jsx(M.Input,{autoFocus:!0,className:"richtext-w-full",onChange:r=>A(r.target.value),placeholder:"Text",required:!0,type:"text",value:p}),a.jsx(j.Button,{className:"richtext-flex-1",onClick:Q,children:a.jsx(V.IconComponent,{name:"ChevronUp"})}),a.jsx(j.Button,{className:"richtext-flex-1",onClick:J,children:a.jsx(V.IconComponent,{name:"ChevronDown"})}),a.jsx(j.Button,{className:"richtext-flex-1",onClick:$,children:"Clear"})]}),a.jsx(E.Label,{className:"richtext-mb-[6px]",children:t("editor.replace.dialog.text")}),a.jsx("div",{className:"richtext-mb-[5px] richtext-flex richtext-w-full richtext-max-w-sm richtext-items-center richtext-gap-1.5",children:a.jsx("div",{className:"richtext-relative richtext-w-full richtext-max-w-sm richtext-items-center",children:a.jsx(M.Input,{className:"richtext-w-80",onChange:r=>N(r.target.value),placeholder:"Text",required:!0,type:"text",value:T})})}),a.jsxs("div",{className:"richtext-my-[10px] richtext-flex richtext-items-center richtext-gap-1",children:[a.jsx(ee.Checkbox,{checked:I,onCheckedChange:r=>{H(r),e.commands.setCaseSensitive(r)}}),a.jsx(E.Label,{children:t("editor.replace.caseSensitive")})]}),a.jsxs("div",{className:"richtext-flex richtext-items-center richtext-gap-[10px]",children:[a.jsx(j.Button,{className:"richtext-flex-1",onClick:G,children:t("editor.replace.dialog.text")}),a.jsx(j.Button,{className:"richtext-flex-1",onClick:X,children:t("editor.replaceAll.dialog.text")})]})]})]}):a.jsx(a.Fragment,{})}const C=(t,e)=>e(t.tr);function se(t,e,s){return RegExp(e?t.replace(/[$()*+.?[\\\]^{|}]/g,String.raw`\$&`):t,s?"gu":"gui")}function re(t,e,s,n){const u=[],o=[];let c=[],x=0;if(!e)return{decorationsToReturn:b.DecorationSet.empty,results:[]};t==null||t.descendants((h,i)=>{h.isText?c[x]?c[x]={text:c[x].text+h.text,pos:c[x].pos}:c[x]={text:`${h.text}`,pos:i}:x+=1}),c=c.filter(Boolean);for(const h of c){const{text:i,pos:g}=h,d=Array.from(i.matchAll(e)).filter(([p])=>p.trim());for(const p of d){if(p[0]==="")break;p.index!==void 0&&o.push({from:g+p.index,to:g+p.index+p[0].length})}}for(const[h,i]of o.entries()){const g=h===n?`${s} ${s}-current`:s,d=b.Decoration.inline(i.from,i.to,{class:g});u.push(d)}return{decorationsToReturn:b.DecorationSet.create(t,u),results:o}}function K(t,e,{state:s,dispatch:n}){if(!e[0])return;const{from:o,to:c}=e[0];n&&n(s.tr.insertText(t,o,c))}function ne(t,e,s,n){const u=e+1;if(!n[u])return null;const{from:o,to:c}=n[e],x=c-o-t.length+s,{from:h,to:i}=n[u];return n[u]={to:i-x,from:h-x},[x,n]}function ce(t,e,{tr:s,dispatch:n}){let u=0,o=e.slice();if(o.length!==0){for(let c=0;c<o.length;c+=1){const{from:x,to:h}=o[c];s.insertText(t,x,h);const i=ne(t,c,u,o);i&&(u=i[0],o=i[1])}n(s)}}const W=Y.Extension.create({name:"searchAndReplace",addOptions(){var t;return{...(t=this.parent)==null?void 0:t.call(this),searchTerm:"",replaceTerm:"",results:[],searchResultClass:"search-result",searchResultCurrentClass:"search-result-current",caseSensitive:!1,disableRegex:!0,onChange:()=>{},button:({editor:e,t:s})=>({componentProps:{action:()=>{},icon:"SearchAndReplace",tooltip:s("editor.searchAndReplace.tooltip"),isActive:()=>!0,editor:e}})}},addStorage(){return{searchTerm:"",replaceTerm:"",results:[],lastSearchTerm:"",caseSensitive:!1,lastCaseSensitive:!1,resultIndex:0,lastResultIndex:0}},addCommands(){return{setSearchTerm:t=>({editor:e,state:s,dispatch:n})=>(e.storage.searchAndReplace.searchTerm=t,C(s,n),!1),setReplaceTerm:t=>({editor:e,state:s,dispatch:n})=>(e.storage.searchAndReplace.replaceTerm=t,C(s,n),!1),setCaseSensitive:t=>({editor:e,state:s,dispatch:n})=>(e.storage.searchAndReplace.caseSensitive=t,C(s,n),!1),resetIndex:()=>({editor:t,state:e,dispatch:s})=>(t.storage.searchAndReplace.resultIndex=0,C(e,s),!1),nextSearchResult:()=>({editor:t})=>{const{results:e,resultIndex:s}=t.storage.searchAndReplace,n=s+1;return e[n]?t.storage.searchAndReplace.resultIndex=n:t.storage.searchAndReplace.resultIndex=0,!1},previousSearchResult:()=>({editor:t})=>{const{results:e,resultIndex:s}=t.storage.searchAndReplace,n=s-1;return e[n]?t.storage.searchAndReplace.resultIndex=n:t.storage.searchAndReplace.resultIndex=e.length-1,!1},replace:()=>({editor:t,state:e,dispatch:s})=>{const{replaceTerm:n,results:u,resultIndex:o}=t.storage.searchAndReplace,c=u[o];return c?(K(n,[c],{state:e,dispatch:s}),t.storage.searchAndReplace.results.splice(o,1)):(K(n,u,{state:e,dispatch:s}),t.storage.searchAndReplace.results.shift()),C(e,s),!1},replaceAll:()=>({editor:t,tr:e,state:s,dispatch:n})=>{const{replaceTerm:u,results:o}=t.storage.searchAndReplace;return ce(u,o,{tr:e,dispatch:n}),t.storage.searchAndReplace.resultIndex=0,t.storage.searchAndReplace.results=[],C(s,n),!1}}},addProseMirrorPlugins(){const t=this.editor,{searchResultClass:e,disableRegex:s}=this.options,n=c=>t.storage.searchAndReplace.lastSearchTerm=c,u=c=>t.storage.searchAndReplace.lastCaseSensitive=c,o=c=>t.storage.searchAndReplace.lastResultIndex=c;return[new F.Plugin({key:new F.PluginKey(`richtextCustomPlugin${this.name}`),state:{init:()=>b.DecorationSet.empty,apply({doc:c,docChanged:x},h){const{searchTerm:i,lastSearchTerm:g,caseSensitive:d,lastCaseSensitive:p,resultIndex:A,lastResultIndex:T}=t.storage.searchAndReplace;if(!x&&g===i&&p===d&&T===A)return h;if(n(i),u(d),o(A),!i)return t.storage.searchAndReplace.results=[],b.DecorationSet.empty;const{decorationsToReturn:N,results:I}=re(c,se(i,s,d),e,A);return t.storage.searchAndReplace.results=I,N}},props:{decorations(c){return this.getState(c)}}})]}});exports.RichTextSearchAndReplace=te;exports.SearchAndReplace=W;
|
package/lib/SearchAndReplace.js
CHANGED
|
@@ -1,24 +1,29 @@
|
|
|
1
|
-
import { E as Q } from "./clsx-
|
|
1
|
+
import { E as Q } from "./clsx-m_C5j3RU.js";
|
|
2
2
|
import { Plugin as X, PluginKey as Y } from "@tiptap/pm/state";
|
|
3
3
|
import { DecorationSet as $, Decoration as Z } from "@tiptap/pm/view";
|
|
4
4
|
import { jsx as u, Fragment as _, jsxs as T } from "react/jsx-runtime";
|
|
5
5
|
import { useState as b, useEffect as k } from "react";
|
|
6
|
-
import {
|
|
7
|
-
import "./
|
|
8
|
-
import { u as
|
|
9
|
-
import { P as
|
|
10
|
-
|
|
11
|
-
|
|
6
|
+
import { A as ee } from "./toggle-CaSwYCk4.js";
|
|
7
|
+
import { f as te, u as se, d as re } from "./useButtonProps-D-ruygH7.js";
|
|
8
|
+
import { u as ne } from "./index-BGd2HiwP.js";
|
|
9
|
+
import { P as ce, a as ae, b as le } from "./popover-BC7FRr8B.js";
|
|
10
|
+
import { L as B } from "./label-ClsOg9Hr.js";
|
|
11
|
+
import { I as V } from "./input-C_J-pfTx.js";
|
|
12
|
+
import { B as N } from "./button-090-I3tp.js";
|
|
13
|
+
import { I as q } from "./Icon-BvGyfX2j.js";
|
|
14
|
+
import { C as oe } from "./checkbox-DiXWHAI0.js";
|
|
15
|
+
function ye() {
|
|
16
|
+
const { t } = ne(), e = te(), s = se(pe.name), {
|
|
12
17
|
icon: n = void 0,
|
|
13
18
|
tooltip: i = void 0,
|
|
14
19
|
shortcutKeys: l = void 0,
|
|
15
20
|
tooltipOptions: c = {},
|
|
16
21
|
action: h = void 0,
|
|
17
22
|
isActive: m = void 0
|
|
18
|
-
} = (s == null ? void 0 : s.componentProps) ?? {}, { disabled: o } =
|
|
19
|
-
var r, a, g,
|
|
20
|
-
|
|
21
|
-
`${((a = (r = e == null ? void 0 : e.storage) == null ? void 0 : r.searchAndReplace) == null ? void 0 : a.resultIndex) + 1}/${(
|
|
23
|
+
} = (s == null ? void 0 : s.componentProps) ?? {}, { disabled: o } = re(m), [f, d] = b(!1), [p, A] = b(""), [S, w] = b(""), [I, M] = b(!1), [W, D] = b(""), y = () => {
|
|
24
|
+
var r, a, g, x;
|
|
25
|
+
D(
|
|
26
|
+
`${((a = (r = e == null ? void 0 : e.storage) == null ? void 0 : r.searchAndReplace) == null ? void 0 : a.resultIndex) + 1}/${(x = (g = e == null ? void 0 : e.storage) == null ? void 0 : g.searchAndReplace) == null ? void 0 : x.results.length}`
|
|
22
27
|
);
|
|
23
28
|
};
|
|
24
29
|
k(() => {
|
|
@@ -27,20 +32,20 @@ function Ce() {
|
|
|
27
32
|
const H = () => {
|
|
28
33
|
o || h && h();
|
|
29
34
|
}, L = (r = !1) => {
|
|
30
|
-
var a, g,
|
|
31
|
-
e && (r && ((g = (a = e == null ? void 0 : e.commands) == null ? void 0 : a.resetIndex) == null || g.call(a)), (R = (
|
|
35
|
+
var a, g, x, R, v, F, P, O;
|
|
36
|
+
e && (r && ((g = (a = e == null ? void 0 : e.commands) == null ? void 0 : a.resetIndex) == null || g.call(a)), (R = (x = e == null ? void 0 : e.commands) == null ? void 0 : x.setSearchTerm) == null || R.call(x, p), (F = (v = e == null ? void 0 : e.commands) == null ? void 0 : v.setReplaceTerm) == null || F.call(v, S), (O = (P = e == null ? void 0 : e.commands) == null ? void 0 : P.setCaseSensitive) == null || O.call(P, I), y());
|
|
32
37
|
}, E = () => {
|
|
33
38
|
var R, v;
|
|
34
39
|
if (!e) return;
|
|
35
40
|
const { results: r, resultIndex: a } = e.storage.searchAndReplace, g = r[a];
|
|
36
41
|
if (!g) return;
|
|
37
42
|
(v = (R = e == null ? void 0 : e.commands) == null ? void 0 : R.setTextSelection) == null || v.call(R, g);
|
|
38
|
-
const { node:
|
|
39
|
-
|
|
43
|
+
const { node: x } = e.view.domAtPos(e.state.selection.anchor);
|
|
44
|
+
x instanceof HTMLElement && x.scrollIntoView({ behavior: "smooth", block: "center" }), y();
|
|
40
45
|
};
|
|
41
46
|
k(() => {
|
|
42
|
-
|
|
43
|
-
}, [
|
|
47
|
+
p.trim() || j(), p.trim() && L(!0);
|
|
48
|
+
}, [p]), k(() => {
|
|
44
49
|
S.trim() && L();
|
|
45
50
|
}, [S]), k(() => {
|
|
46
51
|
L(!0);
|
|
@@ -54,16 +59,16 @@ function Ce() {
|
|
|
54
59
|
}, G = () => {
|
|
55
60
|
var r, a;
|
|
56
61
|
(a = (r = e == null ? void 0 : e.commands) == null ? void 0 : r.previousSearchResult) == null || a.call(r), E();
|
|
57
|
-
},
|
|
62
|
+
}, j = () => {
|
|
58
63
|
var r, a;
|
|
59
64
|
A(""), w(""), (a = (r = e == null ? void 0 : e.commands) == null ? void 0 : r.resetIndex) == null || a.call(r), y();
|
|
60
65
|
}, J = () => {
|
|
61
66
|
var r, a;
|
|
62
|
-
(a = (r = e == null ? void 0 : e.commands) == null ? void 0 : r.replaceAll) == null || a.call(r),
|
|
67
|
+
(a = (r = e == null ? void 0 : e.commands) == null ? void 0 : r.replaceAll) == null || a.call(r), D("0/0");
|
|
63
68
|
};
|
|
64
|
-
return s ? /* @__PURE__ */ T(
|
|
65
|
-
/* @__PURE__ */ u(
|
|
66
|
-
|
|
69
|
+
return s ? /* @__PURE__ */ T(ce, { onOpenChange: d, open: f, children: [
|
|
70
|
+
/* @__PURE__ */ u(ae, { asChild: !0, disabled: o, children: /* @__PURE__ */ u(
|
|
71
|
+
ee,
|
|
67
72
|
{
|
|
68
73
|
action: H,
|
|
69
74
|
disabled: o,
|
|
@@ -73,7 +78,7 @@ function Ce() {
|
|
|
73
78
|
tooltipOptions: c
|
|
74
79
|
}
|
|
75
80
|
) }),
|
|
76
|
-
/* @__PURE__ */ T(
|
|
81
|
+
/* @__PURE__ */ T(le, { align: "start", className: "richtext-w-full", hideWhenDetached: !0, side: "bottom", children: [
|
|
77
82
|
/* @__PURE__ */ T("div", { className: "richtext-mb-[6px] richtext-flex richtext-items-center richtext-justify-between", children: [
|
|
78
83
|
/* @__PURE__ */ u(B, { children: t("editor.search.dialog.text") }),
|
|
79
84
|
/* @__PURE__ */ u("span", { className: "richtext-font-semibold", children: W })
|
|
@@ -88,12 +93,12 @@ function Ce() {
|
|
|
88
93
|
placeholder: "Text",
|
|
89
94
|
required: !0,
|
|
90
95
|
type: "text",
|
|
91
|
-
value:
|
|
96
|
+
value: p
|
|
92
97
|
}
|
|
93
98
|
),
|
|
94
99
|
/* @__PURE__ */ u(N, { className: "richtext-flex-1", onClick: G, children: /* @__PURE__ */ u(q, { name: "ChevronUp" }) }),
|
|
95
100
|
/* @__PURE__ */ u(N, { className: "richtext-flex-1", onClick: z, children: /* @__PURE__ */ u(q, { name: "ChevronDown" }) }),
|
|
96
|
-
/* @__PURE__ */ u(N, { className: "richtext-flex-1", onClick:
|
|
101
|
+
/* @__PURE__ */ u(N, { className: "richtext-flex-1", onClick: j, children: "Clear" })
|
|
97
102
|
] }),
|
|
98
103
|
/* @__PURE__ */ u(B, { className: "richtext-mb-[6px]", children: t("editor.replace.dialog.text") }),
|
|
99
104
|
/* @__PURE__ */ u("div", { className: "richtext-mb-[5px] richtext-flex richtext-w-full richtext-max-w-sm richtext-items-center richtext-gap-1.5", children: /* @__PURE__ */ u("div", { className: "richtext-relative richtext-w-full richtext-max-w-sm richtext-items-center", children: /* @__PURE__ */ u(
|
|
@@ -109,7 +114,7 @@ function Ce() {
|
|
|
109
114
|
) }) }),
|
|
110
115
|
/* @__PURE__ */ T("div", { className: "richtext-my-[10px] richtext-flex richtext-items-center richtext-gap-1", children: [
|
|
111
116
|
/* @__PURE__ */ u(
|
|
112
|
-
|
|
117
|
+
oe,
|
|
113
118
|
{
|
|
114
119
|
checked: I,
|
|
115
120
|
onCheckedChange: (r) => {
|
|
@@ -151,12 +156,12 @@ function ue(t, e, s, n) {
|
|
|
151
156
|
} : h += 1;
|
|
152
157
|
}), c = c.filter(Boolean);
|
|
153
158
|
for (const m of c) {
|
|
154
|
-
const { text: o, pos: f } = m, d = Array.from(o.matchAll(e)).filter(([
|
|
155
|
-
for (const
|
|
156
|
-
if (
|
|
157
|
-
|
|
158
|
-
from: f +
|
|
159
|
-
to: f +
|
|
159
|
+
const { text: o, pos: f } = m, d = Array.from(o.matchAll(e)).filter(([p]) => p.trim());
|
|
160
|
+
for (const p of d) {
|
|
161
|
+
if (p[0] === "") break;
|
|
162
|
+
p.index !== void 0 && l.push({
|
|
163
|
+
from: f + p.index,
|
|
164
|
+
to: f + p.index + p[0].length
|
|
160
165
|
});
|
|
161
166
|
}
|
|
162
167
|
}
|
|
@@ -197,7 +202,7 @@ function me(t, e, { tr: s, dispatch: n }) {
|
|
|
197
202
|
n(s);
|
|
198
203
|
}
|
|
199
204
|
}
|
|
200
|
-
const
|
|
205
|
+
const pe = Q.create({
|
|
201
206
|
name: "searchAndReplace",
|
|
202
207
|
addOptions() {
|
|
203
208
|
var t;
|
|
@@ -273,11 +278,11 @@ const xe = Q.create({
|
|
|
273
278
|
searchTerm: o,
|
|
274
279
|
lastSearchTerm: f,
|
|
275
280
|
caseSensitive: d,
|
|
276
|
-
lastCaseSensitive:
|
|
281
|
+
lastCaseSensitive: p,
|
|
277
282
|
resultIndex: A,
|
|
278
283
|
lastResultIndex: S
|
|
279
284
|
} = t.storage.searchAndReplace;
|
|
280
|
-
if (!h && f === o &&
|
|
285
|
+
if (!h && f === o && p === d && S === A)
|
|
281
286
|
return m;
|
|
282
287
|
if (n(o), i(d), l(A), !o)
|
|
283
288
|
return t.storage.searchAndReplace.results = [], $.empty;
|
|
@@ -300,6 +305,6 @@ const xe = Q.create({
|
|
|
300
305
|
}
|
|
301
306
|
});
|
|
302
307
|
export {
|
|
303
|
-
|
|
304
|
-
|
|
308
|
+
ye as RichTextSearchAndReplace,
|
|
309
|
+
pe as SearchAndReplace
|
|
305
310
|
};
|
package/lib/SlashCommand.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("./clsx-CXbNJWDD.cjs"),u=require("@tiptap/pm/state"),d=require("./index-Cs6cp0Y6.cjs"),r=require("./SlashCommandNodeView-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("./clsx-CXbNJWDD.cjs"),u=require("@tiptap/pm/state"),d=require("./index-Cs6cp0Y6.cjs"),r=require("./SlashCommandNodeView-CUJrDQS7.cjs"),a=require("./updatePosition-Cjuj2E26.cjs"),s=require("react/jsx-runtime"),l=require("react"),m=require("./index-DgOXAdKt.cjs");function c({commandList:e}){const[,t]=r.useSignalCommandList(),{t:n}=m.useLocale();return l.useEffect(()=>{if(!(e!=null&&e.length)){const o=r.renderCommandListDefault({t:n});t(o);return}t(e)},[n,e]),s.jsx(s.Fragment,{})}const C=i.Extension.create({name:"richtextSlashCommand",priority:200,addProseMirrorPlugins(){return[d.Suggestion({pluginKey:new u.PluginKey("richtextSlashCommandPlugin"),editor:this.editor,char:"/",command:({editor:e,range:t,props:n})=>{const{view:o}=e;n.action({editor:e,range:t}),o.focus()},render:()=>{let e;return{onStart:t=>{t.clientRect&&(e=new i.ReactRenderer(r.SlashCommandNodeView,{props:t,editor:t.editor}),e.element.style.position="absolute",document.body.appendChild(e.element),a.updatePosition(t.editor,e.element))},onUpdate(t){e.updateProps(t),t.clientRect&&a.updatePosition(t.editor,e.element)},onKeyDown(t){var n;return t.event.key==="Escape"?(e.destroy(),e.element.remove(),!0):(n=e.ref)==null?void 0:n.onKeyDown(t)},onExit(){e&&(e.destroy(),e.element.remove())}}}})]}});exports.renderCommandListDefault=r.renderCommandListDefault;exports.useFilterCommandList=r.useFilterCommandList;exports.SlashCommand=C;exports.SlashCommandList=c;
|
package/lib/SlashCommand.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { E as i, R as a } from "./clsx-
|
|
1
|
+
import { E as i, R as a } from "./clsx-m_C5j3RU.js";
|
|
2
2
|
import { PluginKey as m } from "@tiptap/pm/state";
|
|
3
|
-
import { S as s } from "./index-
|
|
4
|
-
import { u, r as l, S as d } from "./SlashCommandNodeView-
|
|
5
|
-
import { a as b } from "./SlashCommandNodeView-
|
|
6
|
-
import { u as o } from "./updatePosition-
|
|
3
|
+
import { S as s } from "./index-C8FjP66D.js";
|
|
4
|
+
import { u, r as l, S as d } from "./SlashCommandNodeView-DS9FqMiY.js";
|
|
5
|
+
import { a as b } from "./SlashCommandNodeView-DS9FqMiY.js";
|
|
6
|
+
import { u as o } from "./updatePosition-DvfTZHcH.js";
|
|
7
7
|
import { jsx as f, Fragment as c } from "react/jsx-runtime";
|
|
8
8
|
import { useEffect as h } from "react";
|
|
9
9
|
import { u as C } from "./index-BGd2HiwP.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";const d=require("react/jsx-runtime"),u=require("react"),w=require("./events.constant-Bke62qxm.cjs"),g=require("./index-DgOXAdKt.cjs"),H=require("./index-BXh8X1ch.cjs"),C=require("./index-NsYff_Ni.cjs"),q=require("./label-BgIVynq3.cjs"),j=require("./Icon-wjwoRc9F.cjs");function E({t:n}){const o=[{name:"format",title:n("editor.slash.format"),commands:[]},{name:"insert",title:n("editor.slash.insert"),commands:[]}];return g.HEADINGS.forEach(e=>{o[0].commands.push({name:`heading${e}`,label:n(e==="Paragraph"?"editor.paragraph.tooltip":`editor.heading.h${e}.tooltip`),aliases:[`h${e}`,"bt",`bt${e}`],iconName:`Heading${e}`,isActive:t=>e==="Paragraph"?!1:t.isActive("heading",{level:e})||!1,action:({editor:t,range:l})=>{const s=g.HEADINGS.find(m=>t.isActive("heading",{level:m}));if(e==="Paragraph"){s!==void 0&&s!=="Paragraph"&&t.commands.toggleHeading({level:s}),t.chain().focus().deleteRange(l).run();return}if(e){t.chain().focus().deleteRange(l).setHeading({level:e}).run();return}t.chain().focus().deleteRange(l).run()}})}),o[0].commands.push({name:"bulletList",label:n("editor.bulletlist.tooltip"),aliases:["ul","yxlb"],iconName:"List",isActive:e=>e.isActive("bulletList"),action:({editor:e,range:t})=>{e.chain().focus().deleteRange(t).toggleBulletList().run()}}),o[0].commands.push({name:"orderedlist",label:n("editor.orderedlist.tooltip"),aliases:["ol","yxlb"],iconName:"ListOrdered",isActive:e=>e.isActive("orderedList"),action:({editor:e,range:t})=>{e.chain().focus().deleteRange(t).toggleOrderedList().run()}}),o[0].commands.push({name:"taskList",label:n("editor.tasklist.tooltip"),iconName:"ListTodo",description:"Task list with todo items",aliases:["todo"],isActive:e=>e.isActive("taskList"),action:({editor:e,range:t})=>{e.chain().focus().deleteRange(t).toggleTaskList().run()}}),o[0].commands.push({name:"blockquote",label:n("editor.blockquote.tooltip"),description:"插入引入格式",aliases:["yr"],iconName:"TextQuote",isActive:e=>e.isActive("blockquote"),action:({editor:e,range:t})=>{e.chain().focus().deleteRange(t).setBlockquote().run()}}),o[0].commands.push({name:"codeBlock",label:n("editor.codeblock.tooltip"),iconName:"Code2",description:"Code block with syntax highlighting",shouldBeHidden:e=>e.isActive("columns"),isActive:e=>e.isActive("codeBlock"),action:({editor:e,range:t})=>{e.chain().focus().deleteRange(t).setCodeBlock().run()}}),o[1].commands.push({name:"image",label:n("editor.image.tooltip"),iconName:"ImageUp",description:"Insert a image",aliases:["image","tp","tupian"],shouldBeHidden:e=>e.isActive("columns"),action:({editor:e,range:t})=>{e.chain().focus().deleteRange(t).run();const l=w.EVENTS.UPLOAD_IMAGE(e.id);w.emit(l,!0)}}),o[1].commands.push({name:"table",label:n("editor.table.tooltip"),iconName:"Table",description:"Insert a table",aliases:["table","bg","biaoge","biao"],shouldBeHidden:e=>e.isActive("columns"),action:({editor:e,range:t})=>{e.chain().focus().deleteRange(t).insertTable({rows:3,cols:3,withHeaderRow:!1}).run()}}),o[1].commands.push({name:"horizontalRule",label:n("editor.horizontalrule.tooltip"),iconName:"Minus",description:"Insert a horizontal divider",aliases:["hr","fgx","fg"],action:({editor:e,range:t})=>{e.chain().focus().deleteRange(t).setHorizontalRule().run()}}),o[1].commands.push({name:"paywallSeparator",label:"Paywall Separator",iconName:"PaywallIcon",description:"Mark where free content ends and premium content begins",aliases:["paywall","pw","premium","lock"],shouldBeHidden:e=>{let t=!1;return e.state.doc.descendants(l=>{if(l.type.name==="paywallSeparator")return t=!0,!1}),t},action:({editor:e,range:t})=>{e.chain().focus().deleteRange(t).insertPaywall().run()}}),o[1].commands.push({name:"columns",label:n("editor.columns.tooltip"),iconName:"Columns2",description:"Add two column content",action:({editor:e})=>{e.chain().focus().insertColumns({cols:2}).run()}}),o}function N(n,o){return n.map(t=>({...t,commands:t.commands.filter(l=>{const s=l.label.toLowerCase().trim(),m=o.toLowerCase().trim();if(l.aliases){const x=l.aliases.map(h=>h.toLowerCase().trim()),p=s.match(m),r=x.some(h=>h.match(m));return p||r}return s.match(m)})})).filter(t=>t.commands.length>0)}const $=C.y([]);function L(){const[n,o]=C.V($);return[n,o]}function B(n,o){const[e]=L(),[t,l]=u.useState(0),[s,m]=u.useState(0),x=u.useRef(null),{t:p}=g.useLocale(),r=N(e,n.query),h=u.useRef([]);u.useImperativeHandle(o,()=>({onKeyDown:v})),u.useEffect(()=>{if(!x.current)return;const a=s*1e3+t,i=h.current[a];i&&i.scrollIntoView({behavior:"smooth",block:"nearest"})},[t,s]);function v({event:a}){return a.key==="ArrowUp"?(A(),!0):a.key==="ArrowDown"?(R(),!0):a.key==="Enter"?(k(),!0):!1}function A(){var c;if(r.length===0)return!1;let a=t-1,i=s;a<0&&(i=s-1,a=((c=r[i])==null?void 0:c.commands.length)-1||0),i<0&&(i=r.length-1,a=r[i].commands.length-1),l(a),m(i)}function R(){if(r.length===0)return!1;const a=r[s].commands;let i=t+1,c=s;a.length-1<i&&(i=0,c=s+1),r.length-1<c&&(c=0),l(i),m(c)}function k(){if(r.length===0||s===-1||t===-1)return!1;b(s,t)}function b(a,i){const c=r[a].commands[i];n==null||n.command(c)}function I(a,i){b(a,i)}function y(a,i,c){h.current[a*1e3+i]=c}return d.jsx("div",{className:"richtext-max-h-[min(80vh,24rem)] richtext-flex-wrap richtext-overflow-y-auto richtext-overflow-x-hidden richtext-rounded-md !richtext-border !richtext-border-solid !richtext-border-border richtext-bg-popover richtext-p-1 richtext-text-popover-foreground richtext-shadow-md richtext-outline-none","data-richtext-portal":!0,ref:x,children:r!=null&&r.length?d.jsx("div",{className:"richtext-grid richtext-min-w-48 richtext-grid-cols-1 richtext-gap-0.5",children:r==null?void 0:r.map((a,i)=>d.jsxs(u.Fragment,{children:[d.jsx(q.Label,{className:"richtext-mx-[4px] richtext-mb-[4px] richtext-mt-[8px] !richtext-text-[0.65rem] richtext-uppercase",children:a.title}),a.commands.map((c,f)=>d.jsxs("button",{onClick:()=>I(i,f),ref:S=>y(i,f,S),className:H.cn("richtext-flex richtext-w-full richtext-items-center richtext-gap-3 richtext-rounded-sm !richtext-border-none !richtext-bg-transparent richtext-px-2 richtext-py-1.5 richtext-text-left richtext-text-sm richtext-text-foreground !richtext-outline-none richtext-transition-colors hover:!richtext-bg-accent",{"bg-item-active":s===i&&t===f}),children:[c.iconUrl&&d.jsx("img",{alt:"",className:"richtext-size-6",src:c.iconUrl}),c.iconName&&d.jsx(j.IconComponent,{className:"!richtext-mr-1 !richtext-text-lg",name:c.iconName}),c.label]},`command-${f}`))]},`slash-${a.title}`))}):d.jsx("div",{className:"richtext-p-3",children:d.jsx("span",{className:"richtext-text-xs richtext-text-foreground",children:p("editor.slash.empty")})})})}const D=u.forwardRef(B);exports.SlashCommandNodeView=D;exports.renderCommandListDefault=E;exports.useFilterCommandList=N;exports.useSignalCommandList=L;
|