@aswin.dev/editor 0.8.5 → 0.8.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/dist/{AccessibilityPanel-COL6Wm7p.js → AccessibilityPanel-B39ct5ON.js} +2 -2
- package/dist/{AiChatSidebar-DAJOuHPG.js → AiChatSidebar-CYh7SPHW.js} +2 -2
- package/dist/{AiFeatureMenu-CKnEDzme.js → AiFeatureMenu-D9UhqJAa.js} +3 -3
- package/dist/{BlockA11yBadge-Qs6HtXid.js → BlockA11yBadge-Dr854uEe.js} +2 -2
- package/dist/{CloudEditor-BUlmUuhO.js → CloudEditor-BNEIze18.js} +281 -274
- package/dist/{CollaboratorBar-C6TfqpyV.js → CollaboratorBar-DZXuPSfU.js} +2 -2
- package/dist/{CommentsSidebar-DE6ZsM4D.js → CommentsSidebar-BVKFtxml.js} +4 -4
- package/dist/{CountdownBlock-Ba3T-i2X.js → CountdownBlock-CrpaDWze.js} +1 -1
- package/dist/{CountdownToolbar-B9IAZzeV.js → CountdownToolbar-D1tb2T_b.js} +2 -2
- package/dist/{DesignReferenceSidebar-C6yDJlD8.js → DesignReferenceSidebar-_QsmFpE_.js} +44 -44
- package/dist/{ModuleBrowserModal-DUKuDjS-.js → ModuleBrowserModal-Bth1crh_.js} +7 -7
- package/dist/{ModulePreviewCanvas-C9HTjfkN.js → ModulePreviewCanvas-96pndrb9.js} +3 -3
- package/dist/{ParagraphEditor-CFuaZKGk.js → ParagraphEditor-C2d9O2P4.js} +123 -123
- package/dist/{RichTextEditorContent-CrqPQdnk.js → RichTextEditorContent-Cn0ZU41b.js} +3 -3
- package/dist/{SaveModuleDialog-QjgPFEDg.js → SaveModuleDialog-B1EJtMGq.js} +17 -17
- package/dist/{SlidingPillSelect-DfcBdJqN.js → SlidingPillSelect-Dt34f5VF.js} +1 -1
- package/dist/{SnapshotHistory-Dblt21_W.js → SnapshotHistory-Cd-a_xGv.js} +3 -3
- package/dist/{TemplateScoringPanel-CS7o62zS.js → TemplateScoringPanel-C8WixDsv.js} +77 -77
- package/dist/{TestEmailModal-D_y3ZksG.js → TestEmailModal-CEj_81cQ.js} +3 -3
- package/dist/TitleEditor-C8Qyr_U3.js +172 -0
- package/dist/{TplModal-DinL7DhQ.js → TplModal-B_HcUS4S.js} +2 -2
- package/dist/{blockTypeIcons-JjmIZ_Vx.js → blockTypeIcons-CeaSm2Xd.js} +1 -1
- package/dist/bundle-stats.json +6 -6
- package/dist/cdn/chunks/{AccessibilityPanel-BTADkTp2.js → AccessibilityPanel-C8vY7QIF.js} +3 -3
- package/dist/cdn/chunks/{AccessibilityPanel-BTADkTp2.js.map → AccessibilityPanel-C8vY7QIF.js.map} +1 -1
- package/dist/cdn/chunks/{AiFeatureMenu-D99Pw32q.js → AiFeatureMenu-BaUpnF6T.js} +2 -2
- package/dist/cdn/chunks/{AiFeatureMenu-D99Pw32q.js.map → AiFeatureMenu-BaUpnF6T.js.map} +1 -1
- package/dist/cdn/chunks/{BlockA11yBadge-dtyeSSvY.js → BlockA11yBadge-BHkh4Otq.js} +2 -2
- package/dist/cdn/chunks/{BlockA11yBadge-dtyeSSvY.js.map → BlockA11yBadge-BHkh4Otq.js.map} +1 -1
- package/dist/cdn/chunks/{CloudEditor-BBBkTBfW.js → CloudEditor-DUIjZDAS.js} +264 -257
- package/dist/cdn/chunks/{CloudEditor-BBBkTBfW.js.map → CloudEditor-DUIjZDAS.js.map} +1 -1
- package/dist/cdn/chunks/{CollaboratorBar-Cuy1BusU.js → CollaboratorBar-pyuEO5Bm.js} +3 -3
- package/dist/cdn/chunks/{CollaboratorBar-Cuy1BusU.js.map → CollaboratorBar-pyuEO5Bm.js.map} +1 -1
- package/dist/cdn/chunks/{CountdownToolbar-CqFM85Xv.js → CountdownToolbar-CCGHm6Gg.js} +3 -3
- package/dist/cdn/chunks/{CountdownToolbar-CqFM85Xv.js.map → CountdownToolbar-CCGHm6Gg.js.map} +1 -1
- package/dist/cdn/chunks/{ModuleBrowserModal-Dcxtq_dC.js → ModuleBrowserModal-DKsMddYS.js} +6 -6
- package/dist/cdn/chunks/{ModuleBrowserModal-Dcxtq_dC.js.map → ModuleBrowserModal-DKsMddYS.js.map} +1 -1
- package/dist/cdn/chunks/{ModulePreviewCanvas-Didb4ZCU.js → ModulePreviewCanvas-E0mfCUJi.js} +2 -2
- package/dist/cdn/chunks/{ModulePreviewCanvas-Didb4ZCU.js.map → ModulePreviewCanvas-E0mfCUJi.js.map} +1 -1
- package/dist/cdn/chunks/{ParagraphEditor-BX2L35YF.js → ParagraphEditor-DwmzHg6F.js} +116 -116
- package/dist/cdn/chunks/ParagraphEditor-DwmzHg6F.js.map +1 -0
- package/dist/cdn/chunks/{RichTextEditorContent-ywrdsvHY.js → RichTextEditorContent-4-cNqB4H.js} +3 -3
- package/dist/cdn/chunks/{RichTextEditorContent-ywrdsvHY.js.map → RichTextEditorContent-4-cNqB4H.js.map} +1 -1
- package/dist/cdn/chunks/{SaveModuleDialog-Ddp-HCFB.js → SaveModuleDialog-COm3ptOF.js} +3 -3
- package/dist/cdn/chunks/{SaveModuleDialog-Ddp-HCFB.js.map → SaveModuleDialog-COm3ptOF.js.map} +1 -1
- package/dist/cdn/chunks/{SlidingPillSelect-CS6N3vGq.js → SlidingPillSelect-DlgRynQN.js} +2 -2
- package/dist/cdn/chunks/{SlidingPillSelect-CS6N3vGq.js.map → SlidingPillSelect-DlgRynQN.js.map} +1 -1
- package/dist/cdn/chunks/TitleEditor-CE8r8txX.js +171 -0
- package/dist/cdn/chunks/TitleEditor-CE8r8txX.js.map +1 -0
- package/dist/cdn/chunks/{blockTypeIcons-B2x3gJsz.js → blockTypeIcons-BOf7hTFU.js} +3 -3
- package/dist/cdn/chunks/{blockTypeIcons-B2x3gJsz.js.map → blockTypeIcons-BOf7hTFU.js.map} +1 -1
- package/dist/cdn/chunks/{extensions-CdYSoz4B.js → extensions-B5e8Ov02.js} +17 -17
- package/dist/cdn/chunks/{extensions-CdYSoz4B.js.map → extensions-B5e8Ov02.js.map} +1 -1
- package/dist/cdn/chunks/{features-BZeMkHMs.js → features-BHTP4oRU.js} +734 -734
- package/dist/cdn/chunks/features-BHTP4oRU.js.map +1 -0
- package/dist/cdn/chunks/{icons-nP0Wj6Eq.js → icons-DS4IYWzG.js} +2 -2
- package/dist/cdn/chunks/{icons-nP0Wj6Eq.js.map → icons-DS4IYWzG.js.map} +1 -1
- package/dist/cdn/chunks/{media-library-54Ezt5wL.js → media-library-BLLJsLwk.js} +508 -508
- package/dist/cdn/chunks/{media-library-54Ezt5wL.js.map → media-library-BLLJsLwk.js.map} +1 -1
- package/dist/cdn/chunks/{quality-Di1pUcCW.js → quality-DfKLOn8j.js} +290 -290
- package/dist/cdn/chunks/{quality-Di1pUcCW.js.map → quality-DfKLOn8j.js.map} +1 -1
- package/dist/cdn/chunks/{renderer-C4OuJhDG.js → renderer-fG9yLafB.js} +14 -14
- package/dist/cdn/chunks/{renderer-C4OuJhDG.js.map → renderer-fG9yLafB.js.map} +1 -1
- package/dist/cdn/chunks/{src-DF5NNH7S.js → src-DsfVhQaK.js} +4 -4
- package/dist/cdn/chunks/{src-DF5NNH7S.js.map → src-DsfVhQaK.js.map} +1 -1
- package/dist/cdn/chunks/{styles-C9P3yzMF.js → styles-CPUuKOlD.js} +210 -210
- package/dist/cdn/chunks/{styles-C9P3yzMF.js.map → styles-CPUuKOlD.js.map} +1 -1
- package/dist/cdn/chunks/{tiptap-CZ52Pj8k.js → tiptap-q69oUYhb.js} +2 -2
- package/dist/cdn/chunks/{tiptap-CZ52Pj8k.js.map → tiptap-q69oUYhb.js.map} +1 -1
- package/dist/cdn/editor.css +1 -1
- package/dist/cdn/editor.js +130 -123
- package/dist/cdn/editor.js.map +1 -1
- package/dist/{extensions-CNPdJw_8.js → extensions-mwqd2u9M.js} +2 -2
- package/dist/index.d.ts +6 -6
- package/dist/keys-CqdzeWhT.js +10 -0
- package/dist/style.css +1 -1
- package/dist/{styles-ZIYLQwFf.js → styles-BRNubGRJ.js} +287 -287
- package/dist/templatical-editor.js +134 -127
- package/dist/{useCloudI18n-DOKSZql1.js → useCloudI18n-CDhjmAgB.js} +1 -1
- package/dist/{useEditorCore-BHSyoxSK.js → useEditorCore-DB4A_cje.js} +22 -22
- package/dist/{useI18n-C2xQZ6K9.js → useI18n-DLZJ6wNn.js} +1 -1
- package/dist/{useMergeTag-BfVcyNSv.js → useMergeTag-D-kqWENN.js} +2 -2
- package/package.json +7 -7
- package/dist/TitleEditor-CHmL3FFR.js +0 -172
- package/dist/cdn/chunks/ParagraphEditor-BX2L35YF.js.map +0 -1
- package/dist/cdn/chunks/TitleEditor-BTtgZzci.js +0 -171
- package/dist/cdn/chunks/TitleEditor-BTtgZzci.js.map +0 -1
- package/dist/cdn/chunks/features-BZeMkHMs.js.map +0 -1
- package/dist/keys-CvX8D-8C.js +0 -10
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import { C as e, D as t, P as n, X as r, _ as i, b as a, ct as o, dt as s, f as c, ft as l, g as u, h as d, m as f, p, ut as m, v as h, x as g } from "./draggable-C-1_gch3.js";
|
|
2
|
+
import { Ct as _, Q as v, Vt as y, dn as b, en as x, un as S } from "./features-BHTP4oRU.js";
|
|
3
|
+
import { $ as C, T as w, X as T, pt as ee } from "./icons-DS4IYWzG.js";
|
|
4
|
+
import { n as E, t as D } from "./RichTextEditorContent-4-cNqB4H.js";
|
|
5
|
+
//#region src/components/blocks/TitleEditor.vue?vue&type=script&setup=true&lang.ts
|
|
6
|
+
var O = { class: "tpl-text-editor-wrapper tpl:relative" }, k = ["data-tpl-theme", "aria-label"], A = ["aria-label", "title"], j = ["aria-label", "title"], M = ["aria-label", "title"], N = {
|
|
7
|
+
key: 0,
|
|
8
|
+
class: "tpl:mx-1.5 tpl:h-6 tpl:w-px tpl:bg-[var(--tpl-border)]"
|
|
9
|
+
}, P = ["aria-label", "title"], F = {
|
|
10
|
+
key: 1,
|
|
11
|
+
class: "tpl:flex tpl:items-center tpl:gap-2 tpl:px-2 tpl:text-xs tpl:text-[var(--tpl-text-dim)]"
|
|
12
|
+
}, I = /* @__PURE__ */ e({
|
|
13
|
+
__name: "TitleEditor",
|
|
14
|
+
props: {
|
|
15
|
+
block: {},
|
|
16
|
+
toolbarPosition: {}
|
|
17
|
+
},
|
|
18
|
+
emits: ["done"],
|
|
19
|
+
setup(e, { emit: I }) {
|
|
20
|
+
let L = e, R = I, z = t(S, null), B = t(b, null), V = t(x, void 0), te = f(() => V?.value ?? "body"), { t: H } = y(), { editor: U, EditorContent: W, isLoading: G, initError: K, retry: q, showLinkDialog: J, linkUrl: Y, linkDialogRef: X, canRequestMergeTag: Z, openLinkDialog: Q, insertLink: ne, removeLink: re, closeLinkDialog: ie, handleLinkKeydown: ae, handleAddMergeTag: $ } = v({
|
|
21
|
+
blockId: () => L.block.id,
|
|
22
|
+
blockContent: () => L.block.content,
|
|
23
|
+
onDone: () => R("done"),
|
|
24
|
+
editorName: "TitleEditor",
|
|
25
|
+
async loadExtensions({ mergeTags: e, syntax: t, triggerChar: n, autocompleteEnabled: r, suggestionEmptyText: i }) {
|
|
26
|
+
let [{ Editor: a, EditorContent: o }, { default: s }, { default: c }, { MergeTagNode: l, MergeTagSuggestion: u, LogicMergeTagNode: d }] = await Promise.all([
|
|
27
|
+
import("./tiptap-q69oUYhb.js").then((e) => e.i),
|
|
28
|
+
import("./tiptap-q69oUYhb.js").then((e) => e.a),
|
|
29
|
+
import("./tiptap-q69oUYhb.js").then((e) => e.u),
|
|
30
|
+
import("./extensions-B5e8Ov02.js")
|
|
31
|
+
]);
|
|
32
|
+
return {
|
|
33
|
+
TiptapEditor: a,
|
|
34
|
+
EC: o,
|
|
35
|
+
extensions: [
|
|
36
|
+
s.configure({
|
|
37
|
+
heading: !1,
|
|
38
|
+
codeBlock: !1,
|
|
39
|
+
blockquote: !1,
|
|
40
|
+
horizontalRule: !1,
|
|
41
|
+
bulletList: !1,
|
|
42
|
+
orderedList: !1,
|
|
43
|
+
listItem: !1,
|
|
44
|
+
strike: !1
|
|
45
|
+
}),
|
|
46
|
+
c.configure({
|
|
47
|
+
openOnClick: !1,
|
|
48
|
+
HTMLAttributes: {
|
|
49
|
+
target: "_blank",
|
|
50
|
+
rel: "noopener noreferrer"
|
|
51
|
+
}
|
|
52
|
+
}),
|
|
53
|
+
l.configure({
|
|
54
|
+
mergeTags: e,
|
|
55
|
+
syntax: t
|
|
56
|
+
}),
|
|
57
|
+
d.configure({ syntax: t }),
|
|
58
|
+
...r && n && e.length > 0 ? [u.configure({
|
|
59
|
+
mergeTags: e,
|
|
60
|
+
char: n,
|
|
61
|
+
emptyText: i
|
|
62
|
+
})] : []
|
|
63
|
+
]
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
return (t, f) => (n(), h("div", O, [
|
|
68
|
+
(n(), u(p, { to: te.value }, [d("div", {
|
|
69
|
+
"data-tpl-theme": o(B),
|
|
70
|
+
role: "toolbar",
|
|
71
|
+
"aria-label": o(H).titleEditor.toolbar,
|
|
72
|
+
class: "tpl tpl-text-toolbar tpl:pointer-events-auto tpl:fixed tpl:z-popover tpl:flex tpl:items-center tpl:gap-1 tpl:rounded-lg tpl:border tpl:border-[var(--tpl-border)] tpl:bg-[var(--tpl-bg)] tpl:px-3 tpl:py-2 tpl:shadow-lg",
|
|
73
|
+
style: s({
|
|
74
|
+
...o(z),
|
|
75
|
+
top: `${e.toolbarPosition.top}px`,
|
|
76
|
+
left: `${e.toolbarPosition.left}px`,
|
|
77
|
+
transform: "translateY(-100%)"
|
|
78
|
+
})
|
|
79
|
+
}, [!o(G) && o(U) ? (n(), h(c, { key: 0 }, [
|
|
80
|
+
d("button", {
|
|
81
|
+
type: "button",
|
|
82
|
+
class: m(["tpl-text-toolbar-btn", { "tpl-text-toolbar-btn--active": o(U)?.isActive("bold") }]),
|
|
83
|
+
"aria-label": o(H).titleEditor.bold,
|
|
84
|
+
title: o(H).titleEditor.bold,
|
|
85
|
+
onClick: f[0] ||= (e) => o(U)?.chain().focus().toggleBold().run()
|
|
86
|
+
}, [g(o(ee), {
|
|
87
|
+
size: 16,
|
|
88
|
+
"stroke-width": 2.5
|
|
89
|
+
})], 10, A),
|
|
90
|
+
d("button", {
|
|
91
|
+
type: "button",
|
|
92
|
+
class: m(["tpl-text-toolbar-btn", { "tpl-text-toolbar-btn--active": o(U)?.isActive("italic") }]),
|
|
93
|
+
"aria-label": o(H).titleEditor.italic,
|
|
94
|
+
title: o(H).titleEditor.italic,
|
|
95
|
+
onClick: f[1] ||= (e) => o(U)?.chain().focus().toggleItalic().run()
|
|
96
|
+
}, [g(o(C), {
|
|
97
|
+
size: 16,
|
|
98
|
+
"stroke-width": 2
|
|
99
|
+
})], 10, j),
|
|
100
|
+
f[6] ||= d("span", {
|
|
101
|
+
class: "tpl:mx-1.5 tpl:h-6 tpl:w-px tpl:bg-[var(--tpl-border)]",
|
|
102
|
+
"aria-hidden": "true"
|
|
103
|
+
}, null, -1),
|
|
104
|
+
d("button", {
|
|
105
|
+
type: "button",
|
|
106
|
+
class: m(["tpl-text-toolbar-btn", { "tpl-text-toolbar-btn--active": o(U)?.isActive("link") }]),
|
|
107
|
+
"aria-label": o(H).titleEditor.addLink,
|
|
108
|
+
title: o(H).titleEditor.addLink,
|
|
109
|
+
onClick: f[2] ||= (...e) => o(Q) && o(Q)(...e)
|
|
110
|
+
}, [g(o(T), {
|
|
111
|
+
size: 16,
|
|
112
|
+
"stroke-width": 2
|
|
113
|
+
})], 10, M),
|
|
114
|
+
o(Z) ? (n(), h("span", N)) : i("", !0),
|
|
115
|
+
o(Z) ? (n(), h("button", {
|
|
116
|
+
key: 1,
|
|
117
|
+
type: "button",
|
|
118
|
+
class: "tpl:flex tpl:h-8 tpl:cursor-pointer tpl:items-center tpl:justify-center tpl:gap-1.5 tpl:rounded tpl:border-none tpl:bg-transparent tpl:px-2.5 tpl:text-xs tpl:font-medium tpl:text-[var(--tpl-text)] tpl:transition-all tpl:duration-150 tpl:hover:bg-[var(--tpl-bg-active)]",
|
|
119
|
+
"aria-label": o(H).mergeTag.add,
|
|
120
|
+
title: o(H).mergeTag.add,
|
|
121
|
+
onClick: f[3] ||= (...e) => o($) && o($)(...e)
|
|
122
|
+
}, [g(o(w), {
|
|
123
|
+
size: 16,
|
|
124
|
+
"stroke-width": 2
|
|
125
|
+
}), a(" " + l(o(H).mergeTag.add), 1)], 8, P)) : i("", !0)
|
|
126
|
+
], 64)) : (n(), h("div", F, [g(o(_), {
|
|
127
|
+
class: "tpl-spinner",
|
|
128
|
+
size: 14,
|
|
129
|
+
"stroke-width": 2
|
|
130
|
+
}), a(" " + l(o(H).errors.editorLoading), 1)]))], 12, k)], 8, ["to"])),
|
|
131
|
+
g(D, {
|
|
132
|
+
editor: o(U),
|
|
133
|
+
"editor-content": o(W),
|
|
134
|
+
"is-loading": o(G),
|
|
135
|
+
"init-error": o(K),
|
|
136
|
+
onRetry: o(q)
|
|
137
|
+
}, null, 8, [
|
|
138
|
+
"editor",
|
|
139
|
+
"editor-content",
|
|
140
|
+
"is-loading",
|
|
141
|
+
"init-error",
|
|
142
|
+
"onRetry"
|
|
143
|
+
]),
|
|
144
|
+
g(E, {
|
|
145
|
+
visible: o(J),
|
|
146
|
+
"is-editing-link": o(U)?.isActive("link") ?? !1,
|
|
147
|
+
"dialog-ref": o(X),
|
|
148
|
+
"onUpdate:dialogRef": f[4] ||= (e) => r(X) ? X.value = e : null,
|
|
149
|
+
"link-url": o(Y),
|
|
150
|
+
"onUpdate:linkUrl": f[5] ||= (e) => r(Y) ? Y.value = e : null,
|
|
151
|
+
onClose: o(ie),
|
|
152
|
+
onInsert: o(ne),
|
|
153
|
+
onRemove: o(re),
|
|
154
|
+
onKeydown: o(ae)
|
|
155
|
+
}, null, 8, [
|
|
156
|
+
"visible",
|
|
157
|
+
"is-editing-link",
|
|
158
|
+
"dialog-ref",
|
|
159
|
+
"link-url",
|
|
160
|
+
"onClose",
|
|
161
|
+
"onInsert",
|
|
162
|
+
"onRemove",
|
|
163
|
+
"onKeydown"
|
|
164
|
+
])
|
|
165
|
+
]));
|
|
166
|
+
}
|
|
167
|
+
});
|
|
168
|
+
//#endregion
|
|
169
|
+
export { I as default };
|
|
170
|
+
|
|
171
|
+
//# sourceMappingURL=TitleEditor-CE8r8txX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TitleEditor-CE8r8txX.js","names":[],"sources":["../../../src/components/blocks/TitleEditor.vue","../../../src/components/blocks/TitleEditor.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { useI18n } from \"../../composables\";\nimport { useRichTextEditor } from \"../../composables/useRichTextEditor\";\nimport type { TitleBlock as TitleBlockType } from \"@aswin.dev/types\";\nimport { Bold, Italic, Link, LoaderCircle, ScanLine } from \"@lucide/vue\";\nimport { inject, computed, type Ref } from \"vue\";\nimport { THEME_STYLES_KEY, UI_THEME_KEY, EDITOR_FLOATING_UI_TELEPORT_KEY } from \"../../keys\";\nimport RichTextLinkDialog from \"./RichTextLinkDialog.vue\";\nimport RichTextEditorContent from \"./RichTextEditorContent.vue\";\n\nconst props = defineProps<{\n block: TitleBlockType;\n toolbarPosition: { top: number; left: number };\n}>();\n\nconst emit = defineEmits<{\n (e: \"done\"): void;\n}>();\n\nconst themeStyles = inject(THEME_STYLES_KEY, null);\nconst tplUiTheme = inject(UI_THEME_KEY, null);\n\nconst floatingTeleportHost = inject<Ref<HTMLElement | null> | undefined>(\n EDITOR_FLOATING_UI_TELEPORT_KEY,\n undefined,\n);\nconst toolbarTeleportTarget = computed(\n () => floatingTeleportHost?.value ?? \"body\",\n);\n\nconst { t } = useI18n();\n\nconst {\n editor,\n EditorContent,\n isLoading,\n initError,\n retry,\n showLinkDialog,\n linkUrl,\n linkDialogRef,\n canRequestMergeTag,\n openLinkDialog,\n insertLink,\n removeLink,\n closeLinkDialog,\n handleLinkKeydown,\n handleAddMergeTag,\n} = useRichTextEditor({\n blockId: () => props.block.id,\n blockContent: () => props.block.content,\n onDone: () => emit(\"done\"),\n editorName: \"TitleEditor\",\n async loadExtensions({\n mergeTags,\n syntax,\n triggerChar,\n autocompleteEnabled,\n suggestionEmptyText,\n }) {\n const [\n { Editor: TiptapEditor, EditorContent: EC },\n { default: StarterKit },\n { default: LinkExt },\n { MergeTagNode, MergeTagSuggestion, LogicMergeTagNode },\n ] = await Promise.all([\n import(\"@tiptap/vue-3\"),\n import(\"@tiptap/starter-kit\"),\n import(\"@tiptap/extension-link\"),\n import(\"../../extensions\"),\n ]);\n\n return {\n TiptapEditor,\n EC,\n extensions: [\n StarterKit.configure({\n heading: false,\n codeBlock: false,\n blockquote: false,\n horizontalRule: false,\n bulletList: false,\n orderedList: false,\n listItem: false,\n strike: false,\n }),\n LinkExt.configure({\n openOnClick: false,\n HTMLAttributes: {\n target: \"_blank\",\n rel: \"noopener noreferrer\",\n },\n }),\n MergeTagNode.configure({ mergeTags, syntax }),\n LogicMergeTagNode.configure({ syntax }),\n ...(autocompleteEnabled && triggerChar && mergeTags.length > 0\n ? [\n MergeTagSuggestion.configure({\n mergeTags,\n char: triggerChar,\n emptyText: suggestionEmptyText,\n }),\n ]\n : []),\n ],\n };\n },\n});\n</script>\n\n<template>\n <div class=\"tpl-text-editor-wrapper tpl:relative\">\n <Teleport :to=\"toolbarTeleportTarget\">\n <div\n :data-tpl-theme=\"tplUiTheme\"\n role=\"toolbar\"\n :aria-label=\"t.titleEditor.toolbar\"\n class=\"tpl tpl-text-toolbar tpl:pointer-events-auto tpl:fixed tpl:z-popover tpl:flex tpl:items-center tpl:gap-1 tpl:rounded-lg tpl:border tpl:border-[var(--tpl-border)] tpl:bg-[var(--tpl-bg)] tpl:px-3 tpl:py-2 tpl:shadow-lg\"\n :style=\"{\n ...themeStyles,\n top: `${toolbarPosition.top}px`,\n left: `${toolbarPosition.left}px`,\n transform: 'translateY(-100%)',\n }\"\n >\n <template v-if=\"!isLoading && editor\">\n <!-- Bold -->\n <button\n type=\"button\"\n class=\"tpl-text-toolbar-btn\"\n :class=\"{\n 'tpl-text-toolbar-btn--active': editor?.isActive('bold'),\n }\"\n :aria-label=\"t.titleEditor.bold\"\n :title=\"t.titleEditor.bold\"\n @click=\"editor?.chain().focus().toggleBold().run()\"\n >\n <Bold :size=\"16\" :stroke-width=\"2.5\" />\n </button>\n <!-- Italic -->\n <button\n type=\"button\"\n class=\"tpl-text-toolbar-btn\"\n :class=\"{\n 'tpl-text-toolbar-btn--active': editor?.isActive('italic'),\n }\"\n :aria-label=\"t.titleEditor.italic\"\n :title=\"t.titleEditor.italic\"\n @click=\"editor?.chain().focus().toggleItalic().run()\"\n >\n <Italic :size=\"16\" :stroke-width=\"2\" />\n </button>\n <span\n class=\"tpl:mx-1.5 tpl:h-6 tpl:w-px tpl:bg-[var(--tpl-border)]\"\n aria-hidden=\"true\"\n ></span>\n <!-- Link -->\n <button\n type=\"button\"\n class=\"tpl-text-toolbar-btn\"\n :class=\"{\n 'tpl-text-toolbar-btn--active': editor?.isActive('link'),\n }\"\n :aria-label=\"t.titleEditor.addLink\"\n :title=\"t.titleEditor.addLink\"\n @click=\"openLinkDialog\"\n >\n <Link :size=\"16\" :stroke-width=\"2\" />\n </button>\n <!-- Add Merge Tag -->\n <span\n v-if=\"canRequestMergeTag\"\n class=\"tpl:mx-1.5 tpl:h-6 tpl:w-px tpl:bg-[var(--tpl-border)]\"\n ></span>\n <button\n v-if=\"canRequestMergeTag\"\n type=\"button\"\n class=\"tpl:flex tpl:h-8 tpl:cursor-pointer tpl:items-center tpl:justify-center tpl:gap-1.5 tpl:rounded tpl:border-none tpl:bg-transparent tpl:px-2.5 tpl:text-xs tpl:font-medium tpl:text-[var(--tpl-text)] tpl:transition-all tpl:duration-150 tpl:hover:bg-[var(--tpl-bg-active)]\"\n :aria-label=\"t.mergeTag.add\"\n :title=\"t.mergeTag.add\"\n @click=\"handleAddMergeTag\"\n >\n <ScanLine :size=\"16\" :stroke-width=\"2\" />\n {{ t.mergeTag.add }}\n </button>\n </template>\n <template v-else>\n <div\n class=\"tpl:flex tpl:items-center tpl:gap-2 tpl:px-2 tpl:text-xs tpl:text-[var(--tpl-text-dim)]\"\n >\n <LoaderCircle class=\"tpl-spinner\" :size=\"14\" :stroke-width=\"2\" />\n {{ t.errors.editorLoading }}\n </div>\n </template>\n </div>\n </Teleport>\n\n <RichTextEditorContent\n :editor=\"editor\"\n :editor-content=\"EditorContent\"\n :is-loading=\"isLoading\"\n :init-error=\"initError\"\n @retry=\"retry\"\n />\n\n <RichTextLinkDialog\n :visible=\"showLinkDialog\"\n :is-editing-link=\"editor?.isActive('link') ?? false\"\n v-model:dialog-ref=\"linkDialogRef\"\n v-model:link-url=\"linkUrl\"\n @close=\"closeLinkDialog\"\n @insert=\"insertLink\"\n @remove=\"removeLink\"\n @keydown=\"handleLinkKeydown\"\n />\n </div>\n</template>\n","<script setup lang=\"ts\">\nimport { useI18n } from \"../../composables\";\nimport { useRichTextEditor } from \"../../composables/useRichTextEditor\";\nimport type { TitleBlock as TitleBlockType } from \"@aswin.dev/types\";\nimport { Bold, Italic, Link, LoaderCircle, ScanLine } from \"@lucide/vue\";\nimport { inject, computed, type Ref } from \"vue\";\nimport { THEME_STYLES_KEY, UI_THEME_KEY, EDITOR_FLOATING_UI_TELEPORT_KEY } from \"../../keys\";\nimport RichTextLinkDialog from \"./RichTextLinkDialog.vue\";\nimport RichTextEditorContent from \"./RichTextEditorContent.vue\";\n\nconst props = defineProps<{\n block: TitleBlockType;\n toolbarPosition: { top: number; left: number };\n}>();\n\nconst emit = defineEmits<{\n (e: \"done\"): void;\n}>();\n\nconst themeStyles = inject(THEME_STYLES_KEY, null);\nconst tplUiTheme = inject(UI_THEME_KEY, null);\n\nconst floatingTeleportHost = inject<Ref<HTMLElement | null> | undefined>(\n EDITOR_FLOATING_UI_TELEPORT_KEY,\n undefined,\n);\nconst toolbarTeleportTarget = computed(\n () => floatingTeleportHost?.value ?? \"body\",\n);\n\nconst { t } = useI18n();\n\nconst {\n editor,\n EditorContent,\n isLoading,\n initError,\n retry,\n showLinkDialog,\n linkUrl,\n linkDialogRef,\n canRequestMergeTag,\n openLinkDialog,\n insertLink,\n removeLink,\n closeLinkDialog,\n handleLinkKeydown,\n handleAddMergeTag,\n} = useRichTextEditor({\n blockId: () => props.block.id,\n blockContent: () => props.block.content,\n onDone: () => emit(\"done\"),\n editorName: \"TitleEditor\",\n async loadExtensions({\n mergeTags,\n syntax,\n triggerChar,\n autocompleteEnabled,\n suggestionEmptyText,\n }) {\n const [\n { Editor: TiptapEditor, EditorContent: EC },\n { default: StarterKit },\n { default: LinkExt },\n { MergeTagNode, MergeTagSuggestion, LogicMergeTagNode },\n ] = await Promise.all([\n import(\"@tiptap/vue-3\"),\n import(\"@tiptap/starter-kit\"),\n import(\"@tiptap/extension-link\"),\n import(\"../../extensions\"),\n ]);\n\n return {\n TiptapEditor,\n EC,\n extensions: [\n StarterKit.configure({\n heading: false,\n codeBlock: false,\n blockquote: false,\n horizontalRule: false,\n bulletList: false,\n orderedList: false,\n listItem: false,\n strike: false,\n }),\n LinkExt.configure({\n openOnClick: false,\n HTMLAttributes: {\n target: \"_blank\",\n rel: \"noopener noreferrer\",\n },\n }),\n MergeTagNode.configure({ mergeTags, syntax }),\n LogicMergeTagNode.configure({ syntax }),\n ...(autocompleteEnabled && triggerChar && mergeTags.length > 0\n ? [\n MergeTagSuggestion.configure({\n mergeTags,\n char: triggerChar,\n emptyText: suggestionEmptyText,\n }),\n ]\n : []),\n ],\n };\n },\n});\n</script>\n\n<template>\n <div class=\"tpl-text-editor-wrapper tpl:relative\">\n <Teleport :to=\"toolbarTeleportTarget\">\n <div\n :data-tpl-theme=\"tplUiTheme\"\n role=\"toolbar\"\n :aria-label=\"t.titleEditor.toolbar\"\n class=\"tpl tpl-text-toolbar tpl:pointer-events-auto tpl:fixed tpl:z-popover tpl:flex tpl:items-center tpl:gap-1 tpl:rounded-lg tpl:border tpl:border-[var(--tpl-border)] tpl:bg-[var(--tpl-bg)] tpl:px-3 tpl:py-2 tpl:shadow-lg\"\n :style=\"{\n ...themeStyles,\n top: `${toolbarPosition.top}px`,\n left: `${toolbarPosition.left}px`,\n transform: 'translateY(-100%)',\n }\"\n >\n <template v-if=\"!isLoading && editor\">\n <!-- Bold -->\n <button\n type=\"button\"\n class=\"tpl-text-toolbar-btn\"\n :class=\"{\n 'tpl-text-toolbar-btn--active': editor?.isActive('bold'),\n }\"\n :aria-label=\"t.titleEditor.bold\"\n :title=\"t.titleEditor.bold\"\n @click=\"editor?.chain().focus().toggleBold().run()\"\n >\n <Bold :size=\"16\" :stroke-width=\"2.5\" />\n </button>\n <!-- Italic -->\n <button\n type=\"button\"\n class=\"tpl-text-toolbar-btn\"\n :class=\"{\n 'tpl-text-toolbar-btn--active': editor?.isActive('italic'),\n }\"\n :aria-label=\"t.titleEditor.italic\"\n :title=\"t.titleEditor.italic\"\n @click=\"editor?.chain().focus().toggleItalic().run()\"\n >\n <Italic :size=\"16\" :stroke-width=\"2\" />\n </button>\n <span\n class=\"tpl:mx-1.5 tpl:h-6 tpl:w-px tpl:bg-[var(--tpl-border)]\"\n aria-hidden=\"true\"\n ></span>\n <!-- Link -->\n <button\n type=\"button\"\n class=\"tpl-text-toolbar-btn\"\n :class=\"{\n 'tpl-text-toolbar-btn--active': editor?.isActive('link'),\n }\"\n :aria-label=\"t.titleEditor.addLink\"\n :title=\"t.titleEditor.addLink\"\n @click=\"openLinkDialog\"\n >\n <Link :size=\"16\" :stroke-width=\"2\" />\n </button>\n <!-- Add Merge Tag -->\n <span\n v-if=\"canRequestMergeTag\"\n class=\"tpl:mx-1.5 tpl:h-6 tpl:w-px tpl:bg-[var(--tpl-border)]\"\n ></span>\n <button\n v-if=\"canRequestMergeTag\"\n type=\"button\"\n class=\"tpl:flex tpl:h-8 tpl:cursor-pointer tpl:items-center tpl:justify-center tpl:gap-1.5 tpl:rounded tpl:border-none tpl:bg-transparent tpl:px-2.5 tpl:text-xs tpl:font-medium tpl:text-[var(--tpl-text)] tpl:transition-all tpl:duration-150 tpl:hover:bg-[var(--tpl-bg-active)]\"\n :aria-label=\"t.mergeTag.add\"\n :title=\"t.mergeTag.add\"\n @click=\"handleAddMergeTag\"\n >\n <ScanLine :size=\"16\" :stroke-width=\"2\" />\n {{ t.mergeTag.add }}\n </button>\n </template>\n <template v-else>\n <div\n class=\"tpl:flex tpl:items-center tpl:gap-2 tpl:px-2 tpl:text-xs tpl:text-[var(--tpl-text-dim)]\"\n >\n <LoaderCircle class=\"tpl-spinner\" :size=\"14\" :stroke-width=\"2\" />\n {{ t.errors.editorLoading }}\n </div>\n </template>\n </div>\n </Teleport>\n\n <RichTextEditorContent\n :editor=\"editor\"\n :editor-content=\"EditorContent\"\n :is-loading=\"isLoading\"\n :init-error=\"initError\"\n @retry=\"retry\"\n />\n\n <RichTextLinkDialog\n :visible=\"showLinkDialog\"\n :is-editing-link=\"editor?.isActive('link') ?? false\"\n v-model:dialog-ref=\"linkDialogRef\"\n v-model:link-url=\"linkUrl\"\n @close=\"closeLinkDialog\"\n @insert=\"insertLink\"\n @remove=\"removeLink\"\n @keydown=\"handleLinkKeydown\"\n />\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;;;EAUA,IAAM,IAAQ,GAKR,IAAO,GAIP,IAAc,EAAO,GAAkB,KAAK,EAC5C,IAAa,EAAO,GAAc,KAAK,EAEvC,IAAuB,EAC3B,GACA,KAAA,EACD,EACK,KAAwB,QACtB,GAAsB,SAAS,OACtC,EAEK,EAAE,SAAM,GAAS,EAEjB,EACJ,WACA,kBACA,cACA,cACA,UACA,mBACA,YACA,kBACA,uBACA,mBACA,gBACA,gBACA,qBACA,uBACA,yBACE,EAAkB;GACpB,eAAe,EAAM,MAAM;GAC3B,oBAAoB,EAAM,MAAM;GAChC,cAAc,EAAK,OAAO;GAC1B,YAAY;GACZ,MAAM,eAAe,EACnB,cACA,WACA,gBACA,wBACA,0BACC;IACD,IAAM,CACJ,EAAE,QAAQ,GAAc,eAAe,KACvC,EAAE,SAAS,KACX,EAAE,SAAS,KACX,EAAE,iBAAc,uBAAoB,0BAClC,MAAM,QAAQ,IAAI;KACpB,OAAO,wBAAA,MAAA,MAAA,EAAA,EAAA;KACP,OAAO,wBAAA,MAAA,MAAA,EAAA,EAAA;KACP,OAAO,wBAAA,MAAA,MAAA,EAAA,EAAA;KACP,OAAO;KACR,CAAC;AAEF,WAAO;KACL;KACA;KACA,YAAY;MACV,EAAW,UAAU;OACnB,SAAS;OACT,WAAW;OACX,YAAY;OACZ,gBAAgB;OAChB,YAAY;OACZ,aAAa;OACb,UAAU;OACV,QAAQ;OACT,CAAC;MACF,EAAQ,UAAU;OAChB,aAAa;OACb,gBAAgB;QACd,QAAQ;QACR,KAAK;QACN;OACF,CAAC;MACF,EAAa,UAAU;OAAE;OAAW;OAAQ,CAAC;MAC7C,EAAkB,UAAU,EAAE,WAAQ,CAAC;MACvC,GAAI,KAAuB,KAAe,EAAU,SAAS,IACzD,CACE,EAAmB,UAAU;OAC3B;OACA,MAAM;OACN,WAAW;OACZ,CAAC,CACJ,GACA,EAAE;MACP;KACF;;GAEJ,CAAC;yBAIA,EAwGM,OAxGN,GAwGM;SAvGJ,EAmFW,GAAA,EAnFA,IAAI,GAAA,OAAqB,EAAA,CAClC,EAiFM,OAAA;IAhFH,kBAAgB,EAAA,EAAU;IAC3B,MAAK;IACJ,cAAY,EAAA,EAAC,CAAC,YAAY;IAC3B,OAAM;IACL,OAAK,EAAA;QAAiB,EAAA,EAAW;aAAoB,EAAA,gBAAgB,IAAG;cAAyB,EAAA,gBAAgB,KAAI;;;QAOrG,EAAA,EAAS,IAAI,EAAA,EAAM,IAAA,GAAA,EAApC,EA4DW,GAAA,EAAA,KAAA,GAAA,EAAA;IA1DT,EAWS,UAAA;KAVP,MAAK;KACL,OAAK,EAAA,CAAC,wBAAsB,EAAA,gCAC4B,EAAA,EAAM,EAAE,SAAQ,OAAA,EAAA,CAAA,CAAA;KAGvE,cAAY,EAAA,EAAC,CAAC,YAAY;KAC1B,OAAO,EAAA,EAAC,CAAC,YAAY;KACrB,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,EAAM,EAAE,OAAK,CAAG,OAAK,CAAG,YAAU,CAAG,KAAG;QAEhD,EAAuC,EAAA,GAAA,EAAA;KAAhC,MAAM;KAAK,gBAAc;;IAGlC,EAWS,UAAA;KAVP,MAAK;KACL,OAAK,EAAA,CAAC,wBAAsB,EAAA,gCAC4B,EAAA,EAAM,EAAE,SAAQ,SAAA,EAAA,CAAA,CAAA;KAGvE,cAAY,EAAA,EAAC,CAAC,YAAY;KAC1B,OAAO,EAAA,EAAC,CAAC,YAAY;KACrB,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,EAAM,EAAE,OAAK,CAAG,OAAK,CAAG,cAAY,CAAG,KAAG;QAElD,EAAuC,EAAA,EAAA,EAAA;KAA9B,MAAM;KAAK,gBAAc;;aAEpC,EAGQ,QAAA;KAFN,OAAM;KACN,eAAY;;IAGd,EAWS,UAAA;KAVP,MAAK;KACL,OAAK,EAAA,CAAC,wBAAsB,EAAA,gCAC4B,EAAA,EAAM,EAAE,SAAQ,OAAA,EAAA,CAAA,CAAA;KAGvE,cAAY,EAAA,EAAC,CAAC,YAAY;KAC1B,OAAO,EAAA,EAAC,CAAC,YAAY;KACrB,SAAK,AAAA,EAAA,QAAA,GAAA,MAAE,EAAA,EAAA,IAAA,EAAA,EAAA,CAAA,GAAA,EAAc;QAEtB,EAAqC,EAAA,EAAA,EAAA;KAA9B,MAAM;KAAK,gBAAc;;IAI1B,EAAA,EAAkB,IAAA,GAAA,EAD1B,EAGQ,QAHR,EAGQ,IAAA,EAAA,IAAA,GAAA;IAEA,EAAA,EAAkB,IAAA,GAAA,EAD1B,EAUS,UAAA;;KARP,MAAK;KACL,OAAM;KACL,cAAY,EAAA,EAAC,CAAC,SAAS;KACvB,OAAO,EAAA,EAAC,CAAC,SAAS;KAClB,SAAK,AAAA,EAAA,QAAA,GAAA,MAAE,EAAA,EAAA,IAAA,EAAA,EAAA,CAAA,GAAA,EAAiB;QAEzB,EAAyC,EAAA,EAAA,EAAA;KAA9B,MAAM;KAAK,gBAAc;UAAK,MACzC,EAAG,EAAA,EAAC,CAAC,SAAS,IAAG,EAAA,EAAA,CAAA,EAAA,GAAA,EAAA,IAAA,EAAA,IAAA,GAAA;mBAInB,EAKM,OALN,GAKM,CAFJ,EAAiE,EAAA,EAAA,EAAA;IAAnD,OAAM;IAAe,MAAM;IAAK,gBAAc;SAAK,MACjE,EAAG,EAAA,EAAC,CAAC,OAAO,cAAa,EAAA,EAAA,CAAA,CAAA,EAAA,EAAA,IAAA,EAAA,CAAA,EAAA,GAAA,CAAA,KAAA,CAAA;GAMjC,EAME,GAAA;IALC,QAAQ,EAAA,EAAM;IACd,kBAAgB,EAAA,EAAa;IAC7B,cAAY,EAAA,EAAS;IACrB,cAAY,EAAA,EAAS;IACrB,SAAO,EAAA,EAAK;;;;;;;;GAGf,EASE,GAAA;IARC,SAAS,EAAA,EAAc;IACvB,mBAAiB,EAAA,EAAM,EAAE,SAAQ,OAAA,IAAA;IAC1B,cAAY,EAAA,EAAa;mDAAA,QAAA,IAAA;IACzB,YAAU,EAAA,EAAO;iDAAA,QAAA,IAAA;IACxB,SAAO,EAAA,GAAe;IACtB,UAAQ,EAAA,GAAU;IAClB,UAAQ,EAAA,GAAU;IAClB,WAAS,EAAA,GAAiB"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { At as e, Tt as t, gt as n, pt as r, xt as i } from "./features-
|
|
2
|
-
import { M as a, R as o, U as s, c, ct as l, et as u, j as d, k as f, o as p, ot as m, s as h } from "./icons-
|
|
1
|
+
import { At as e, Tt as t, gt as n, pt as r, xt as i } from "./features-BHTP4oRU.js";
|
|
2
|
+
import { M as a, R as o, U as s, c, ct as l, et as u, j as d, k as f, o as p, ot as m, s as h } from "./icons-DS4IYWzG.js";
|
|
3
3
|
//#region src/utils/blockTypeIcons.ts
|
|
4
4
|
var g = {
|
|
5
5
|
section: m,
|
|
@@ -22,4 +22,4 @@ var g = {
|
|
|
22
22
|
//#endregion
|
|
23
23
|
export { g as t };
|
|
24
24
|
|
|
25
|
-
//# sourceMappingURL=blockTypeIcons-
|
|
25
|
+
//# sourceMappingURL=blockTypeIcons-BOf7hTFU.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blockTypeIcons-
|
|
1
|
+
{"version":3,"file":"blockTypeIcons-BOf7hTFU.js","names":[],"sources":["../../../src/utils/blockTypeIcons.ts"],"sourcesContent":["import {\n ClipboardList,\n Code,\n Columns3,\n Heading,\n Image,\n Minus,\n MoveVertical,\n Navigation,\n Pilcrow,\n Play,\n RectangleHorizontal,\n Share2,\n Table,\n TextCursor,\n Ticket,\n Timer,\n} from \"@lucide/vue\";\nimport type { Component } from \"vue\";\n\nexport const blockTypeIcons: Record<string, Component> = {\n section: Columns3,\n title: Heading,\n paragraph: Pilcrow,\n image: Image,\n button: RectangleHorizontal,\n input: TextCursor,\n divider: Minus,\n video: Play,\n social: Share2,\n menu: Navigation,\n table: Table,\n spacer: MoveVertical,\n countdown: Timer,\n form: ClipboardList,\n discountCoupon: Ticket,\n html: Code,\n};\n"],"mappings":";;;AAoBA,IAAa,IAA4C;CACvD,SAAS;CACT,OAAO;CACP,WAAW;CACX,OAAO;CACP,QAAQ;CACR,OAAO;CACP,SAAS;CACT,OAAO;CACP,QAAQ;CACR,MAAM;CACN,OAAO;CACP,QAAQ;CACR,WAAW;CACX,MAAM;CACN,gBAAgB;CAChB,MAAM;CACP"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { A as e, C as t, G as n, I as r, P as i, T as a, W as o, _ as s, c, ct as l, d as u, dt as d, f, ft as p, g as m, h, m as g, r as _, tt as v, u as y, ut as b, v as x } from "./draggable-C-1_gch3.js";
|
|
2
|
-
import {
|
|
3
|
-
import { _ as O, g as k, h as A, n as j, r as M, t as N, v as P, y as F } from "./tiptap-
|
|
2
|
+
import { Mn as S, Nn as C, Vt as w, jn as T, kn as E, nt as D } from "./features-BHTP4oRU.js";
|
|
3
|
+
import { _ as O, g as k, h as A, n as j, r as M, t as N, v as P, y as F } from "./tiptap-q69oUYhb.js";
|
|
4
4
|
//#region src/extensions/FontSize.ts
|
|
5
5
|
var I = A.create({
|
|
6
6
|
name: "fontSize",
|
|
@@ -82,7 +82,7 @@ var I = A.create({
|
|
|
82
82
|
updateAttributes: { type: Function }
|
|
83
83
|
},
|
|
84
84
|
setup(t) {
|
|
85
|
-
let r = t, { syntax: a } = D(), { t: f } =
|
|
85
|
+
let r = t, { syntax: a } = D(), { t: f } = w(), _ = g(() => C(r.node.attrs.value, a)), S = g(() => T(r.node.attrs.value, a)), E = v(!1), O = v(""), k = v(null), A = !1;
|
|
86
86
|
function M() {
|
|
87
87
|
O.value = r.node.attrs.value, A = !1, E.value = !0, e(() => {
|
|
88
88
|
k.value?.focus(), k.value?.select();
|
|
@@ -98,7 +98,7 @@ var I = A.create({
|
|
|
98
98
|
}
|
|
99
99
|
e !== r.node.attrs.value && r.updateAttributes({
|
|
100
100
|
value: e,
|
|
101
|
-
keyword: C(e, a) ?
|
|
101
|
+
keyword: C(e, a) ? T(e, a) : ""
|
|
102
102
|
}), E.value = !1;
|
|
103
103
|
}
|
|
104
104
|
function P(e) {
|
|
@@ -128,7 +128,7 @@ var I = A.create({
|
|
|
128
128
|
"data-tooltip": t.node.attrs.value,
|
|
129
129
|
onClick: u(M, ["stop"]),
|
|
130
130
|
onKeydown: [y(u(M, ["stop"]), ["enter"]), y(u(M, ["prevent", "stop"]), ["space"])]
|
|
131
|
-
}, p(
|
|
131
|
+
}, p(S.value), 41, ee)) : (i(), x("span", {
|
|
132
132
|
key: 2,
|
|
133
133
|
role: "button",
|
|
134
134
|
tabindex: "0",
|
|
@@ -186,7 +186,7 @@ var H = O.create({
|
|
|
186
186
|
inline: !0,
|
|
187
187
|
atom: !0,
|
|
188
188
|
addOptions() {
|
|
189
|
-
return { syntax:
|
|
189
|
+
return { syntax: E.liquid };
|
|
190
190
|
},
|
|
191
191
|
addAttributes() {
|
|
192
192
|
return {
|
|
@@ -209,7 +209,7 @@ var H = O.create({
|
|
|
209
209
|
{},
|
|
210
210
|
e.attrs.value
|
|
211
211
|
];
|
|
212
|
-
let n =
|
|
212
|
+
let n = T(e.attrs.value, this.options.syntax);
|
|
213
213
|
return [
|
|
214
214
|
"span",
|
|
215
215
|
F(t, {
|
|
@@ -234,7 +234,7 @@ var H = O.create({
|
|
|
234
234
|
handler: ({ state: e, range: t, match: n }) => {
|
|
235
235
|
let r = n[0];
|
|
236
236
|
if (!C(r, this.options.syntax)) return;
|
|
237
|
-
let i =
|
|
237
|
+
let i = T(r, this.options.syntax), a = this.type.create({
|
|
238
238
|
value: r,
|
|
239
239
|
keyword: i
|
|
240
240
|
});
|
|
@@ -248,7 +248,7 @@ var H = O.create({
|
|
|
248
248
|
handler: ({ state: e, range: t, match: n }) => {
|
|
249
249
|
let r = n[0];
|
|
250
250
|
if (!C(r, this.options.syntax)) return;
|
|
251
|
-
let i =
|
|
251
|
+
let i = T(r, this.options.syntax), a = this.type.create({
|
|
252
252
|
value: r,
|
|
253
253
|
keyword: i
|
|
254
254
|
});
|
|
@@ -268,7 +268,7 @@ var H = O.create({
|
|
|
268
268
|
updateAttributes: { type: Function }
|
|
269
269
|
},
|
|
270
270
|
setup(t) {
|
|
271
|
-
let r = t, { getMergeTagLabel: a } = D(), { t: s } =
|
|
271
|
+
let r = t, { getMergeTagLabel: a } = D(), { t: s } = w(), d = g(() => a(r.node.attrs.value)), f = v(!1), _ = v(""), b = v(null);
|
|
272
272
|
function S() {
|
|
273
273
|
_.value = r.node.attrs.value, f.value = !0, e(() => {
|
|
274
274
|
b.value?.focus(), b.value?.select();
|
|
@@ -281,7 +281,7 @@ var H = O.create({
|
|
|
281
281
|
label: a(e)
|
|
282
282
|
}), f.value = !1;
|
|
283
283
|
}
|
|
284
|
-
function
|
|
284
|
+
function T(e) {
|
|
285
285
|
e.key === "Enter" ? (e.preventDefault(), C()) : e.key === "Escape" && (f.value = !1);
|
|
286
286
|
}
|
|
287
287
|
return (e, r) => (i(), m(l(j), {
|
|
@@ -298,7 +298,7 @@ var H = O.create({
|
|
|
298
298
|
type: "text",
|
|
299
299
|
class: "tpl:w-32 tpl:rounded tpl:border-none tpl:bg-transparent tpl:px-0.5 tpl:py-0 tpl:text-[1em] tpl:font-medium tpl:outline-none tpl:text-[var(--tpl-primary)]",
|
|
300
300
|
onBlur: C,
|
|
301
|
-
onKeydown:
|
|
301
|
+
onKeydown: T
|
|
302
302
|
}, null, 544)), [[c, _.value]]) : (i(), x("span", {
|
|
303
303
|
key: 1,
|
|
304
304
|
role: "button",
|
|
@@ -344,7 +344,7 @@ var H = O.create({
|
|
|
344
344
|
addOptions() {
|
|
345
345
|
return {
|
|
346
346
|
mergeTags: [],
|
|
347
|
-
syntax:
|
|
347
|
+
syntax: E.liquid
|
|
348
348
|
};
|
|
349
349
|
},
|
|
350
350
|
addAttributes() {
|
|
@@ -363,7 +363,7 @@ var H = O.create({
|
|
|
363
363
|
return [{ tag: "span[data-merge-tag]" }];
|
|
364
364
|
},
|
|
365
365
|
renderHTML({ node: e, HTMLAttributes: t }) {
|
|
366
|
-
let n =
|
|
366
|
+
let n = S(e.attrs.value, this.options.mergeTags);
|
|
367
367
|
return [
|
|
368
368
|
"span",
|
|
369
369
|
F(t, {
|
|
@@ -392,7 +392,7 @@ var H = O.create({
|
|
|
392
392
|
return [new k({
|
|
393
393
|
find: RegExp(this.options.syntax.value.source + "$", ""),
|
|
394
394
|
handler: ({ state: e, range: t, match: n }) => {
|
|
395
|
-
let r = n[0], i =
|
|
395
|
+
let r = n[0], i = S(r, this.options.mergeTags), a = this.type.create({
|
|
396
396
|
label: i,
|
|
397
397
|
value: r
|
|
398
398
|
});
|
|
@@ -404,7 +404,7 @@ var H = O.create({
|
|
|
404
404
|
return [new P({
|
|
405
405
|
find: new RegExp(this.options.syntax.value.source, "g"),
|
|
406
406
|
handler: ({ state: e, range: t, match: n }) => {
|
|
407
|
-
let r = n[0], i =
|
|
407
|
+
let r = n[0], i = S(r, this.options.mergeTags), a = this.type.create({
|
|
408
408
|
label: i,
|
|
409
409
|
value: r
|
|
410
410
|
});
|
|
@@ -595,4 +595,4 @@ var oe = A.create({
|
|
|
595
595
|
//#endregion
|
|
596
596
|
export { I as FontSize, L as LetterSpacing, R as LineHeight, H as LogicMergeTagNode, K as MergeTagNode, oe as MergeTagSuggestion, Q as filterMergeTags, $ as handleSuggestionKeyDown };
|
|
597
597
|
|
|
598
|
-
//# sourceMappingURL=extensions-
|
|
598
|
+
//# sourceMappingURL=extensions-B5e8Ov02.js.map
|