@m2s2/vue-lib 2.0.0 → 2.2.0
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/index.cjs +1 -1
- package/dist/index.mjs +34 -28
- package/dist/index10.cjs +1 -1
- package/dist/index10.mjs +8 -16
- package/dist/index12.cjs +1 -1
- package/dist/index12.mjs +15 -19
- package/dist/index14.cjs +1 -1
- package/dist/index14.mjs +20 -27
- package/dist/index16.cjs +1 -1
- package/dist/index16.mjs +28 -262
- package/dist/index18.cjs +1 -1
- package/dist/index18.mjs +263 -13
- package/dist/index2.cjs +1 -1
- package/dist/index2.mjs +250 -11
- package/dist/index20.cjs +1 -1
- package/dist/index20.mjs +13 -38
- package/dist/index22.cjs +1 -1
- package/dist/index22.mjs +35 -49
- package/dist/index24.cjs +1 -1
- package/dist/index24.mjs +47 -78
- package/dist/index26.cjs +6 -1
- package/dist/index26.mjs +273 -102
- package/dist/index28.cjs +1 -1
- package/dist/index28.mjs +75 -60
- package/dist/index30.cjs +1 -1
- package/dist/index30.mjs +100 -75
- package/dist/index32.cjs +1 -1
- package/dist/index32.mjs +72 -3
- package/dist/index34.cjs +1 -1
- package/dist/index34.mjs +85 -3
- package/dist/index36.cjs +1 -1
- package/dist/index36.mjs +2 -2
- package/dist/index37.cjs +1 -1
- package/dist/index37.mjs +2 -2
- package/dist/index38.cjs +1 -1
- package/dist/index38.mjs +2 -2
- package/dist/index39.cjs +1 -1
- package/dist/index39.mjs +2 -2
- package/dist/index4.cjs +1 -1
- package/dist/index4.mjs +11 -19
- package/dist/index40.cjs +1 -1
- package/dist/index40.mjs +1 -1
- package/dist/index41.cjs +1 -1
- package/dist/index41.mjs +1 -1
- package/dist/index42.cjs +1 -1
- package/dist/index42.mjs +1 -1
- package/dist/index43.cjs +1 -1
- package/dist/index43.mjs +1 -1
- package/dist/index44.cjs +1 -1
- package/dist/index44.mjs +1 -1
- package/dist/index45.cjs +1 -1
- package/dist/index45.mjs +1 -1
- package/dist/index46.cjs +1 -1
- package/dist/index46.mjs +1 -1
- package/dist/index47.cjs +1 -1
- package/dist/index47.mjs +3 -51
- package/dist/index48.cjs +1 -1
- package/dist/index48.mjs +3 -2
- package/dist/index49.cjs +1 -0
- package/dist/index49.mjs +5 -0
- package/dist/index50.cjs +1 -0
- package/dist/index50.mjs +5 -0
- package/dist/index51.cjs +1 -0
- package/dist/index51.mjs +5 -0
- package/dist/index52.cjs +1 -0
- package/dist/index52.mjs +5 -0
- package/dist/index53.cjs +59 -0
- package/dist/index53.mjs +1152 -0
- package/dist/index54.cjs +1 -0
- package/dist/index54.mjs +53 -0
- package/dist/index55.cjs +1 -0
- package/dist/index55.mjs +4 -0
- package/dist/index6.cjs +1 -1
- package/dist/index6.mjs +21 -15
- package/dist/index8.cjs +1 -1
- package/dist/index8.mjs +15 -10
- package/dist/vue-lib/src/components/BlogEditor/BlogEditor.vue.d.ts +16 -0
- package/dist/vue-lib/src/components/BlogEditor/BlogEditor.vue.d.ts.map +1 -0
- package/dist/vue-lib/src/components/Chat/Chat.vue.d.ts +22 -0
- package/dist/vue-lib/src/components/Chat/Chat.vue.d.ts.map +1 -0
- package/dist/vue-lib/src/index.d.ts +2 -0
- package/dist/vue-lib/src/index.d.ts.map +1 -1
- package/dist/vue-lib.css +1 -1
- package/package.json +8 -5
- package/dist/index33.cjs +0 -1
- package/dist/index33.mjs +0 -5
- package/dist/index35.cjs +0 -1
- package/dist/index35.mjs +0 -5
package/dist/index26.mjs
CHANGED
|
@@ -1,112 +1,283 @@
|
|
|
1
|
-
import { defineComponent as
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
class: "
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
key: 1,
|
|
10
|
-
class: "sub-success"
|
|
11
|
-
}, U = {
|
|
12
|
-
key: 1,
|
|
13
|
-
class: "sub-auth"
|
|
14
|
-
}, V = ["disabled"], B = {
|
|
15
|
-
key: 0,
|
|
16
|
-
class: "sub-feedback sub-feedback--success"
|
|
17
|
-
}, D = ["disabled"], E = {
|
|
18
|
-
key: 2,
|
|
19
|
-
class: "sub-feedback sub-feedback--error"
|
|
20
|
-
}, Y = /* @__PURE__ */ k({
|
|
21
|
-
__name: "SubscribeForm",
|
|
1
|
+
import { defineComponent as oe, ref as s, watch as ie, computed as E, openBlock as _, createElementBlock as w, createElementVNode as l, createTextVNode as x, withDirectives as v, vModelText as b, Fragment as W, renderList as j, toDisplayString as P, createCommentVNode as re } from "vue";
|
|
2
|
+
import { marked as ue } from "./index53.mjs";
|
|
3
|
+
const ce = { class: "be-root" }, de = { class: "be-meta" }, ve = { class: "be-field be-field--full" }, be = ["value"], pe = { class: "be-field" }, ge = { class: "be-field" }, fe = { class: "be-field be-field--full" }, me = { class: "be-field be-field--full" }, _e = { class: "be-field" }, we = { class: "be-tags" }, xe = ["onClick", "aria-label"], he = { class: "be-field" }, ke = { class: "be-field be-field--cover" }, ye = { class: "be-cover" }, Ce = ["src"], Ie = { class: "be-cover__pick" }, Pe = { class: "be-editor" }, Te = {
|
|
4
|
+
class: "be-toolbar",
|
|
5
|
+
role: "toolbar",
|
|
6
|
+
"aria-label": "Formatting"
|
|
7
|
+
}, Se = ["title", "onClick"], Ee = { class: "be-panes" }, Ue = { class: "be-pane be-pane--write" }, Be = ["value"], Le = { class: "be-pane be-pane--preview" }, Ve = ["innerHTML"], De = { class: "be-footer" }, He = { class: "be-footer__meta" }, Re = ["disabled"], Ne = /* @__PURE__ */ oe({
|
|
8
|
+
__name: "BlogEditor",
|
|
22
9
|
props: {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
subscribeAuth: {},
|
|
26
|
-
unsubscribeAuth: {}
|
|
10
|
+
initialPost: {},
|
|
11
|
+
coverImageUrl: {}
|
|
27
12
|
},
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
if (!g.value || !a.subscribeAnon) return;
|
|
52
|
-
e.value = "submitting";
|
|
53
|
-
try {
|
|
54
|
-
await a.subscribeAnon(n.value.trim(), b.value.trim()), e.value = "done";
|
|
55
|
-
} catch {
|
|
56
|
-
e.value = "error";
|
|
57
|
-
}
|
|
58
|
-
}
|
|
13
|
+
emits: ["publish", "coverImageSelected"],
|
|
14
|
+
setup(G, { emit: J }) {
|
|
15
|
+
var H, R, M, F, N, O, $, q, A;
|
|
16
|
+
const n = G, U = J, Q = [
|
|
17
|
+
{ label: "Heading 2", icon: "H2", prefix: "## " },
|
|
18
|
+
{ label: "Heading 3", icon: "H3", prefix: "### " },
|
|
19
|
+
{ label: "Bold", icon: "B", wrap: ["**", "**"] },
|
|
20
|
+
{ label: "Italic", icon: "I", wrap: ["*", "*"] },
|
|
21
|
+
{ label: "Inline code", icon: "`", wrap: ["`", "`"] },
|
|
22
|
+
{ label: "Code block", icon: "{ }", block: "\n```\n\n```\n" },
|
|
23
|
+
{ label: "Blockquote", icon: "❝", prefix: "> " },
|
|
24
|
+
{ label: "Link", icon: "⇗", wrap: ["[", "](url)"] },
|
|
25
|
+
{ label: "Image", icon: "⬚", block: `
|
|
26
|
+
` },
|
|
27
|
+
{ label: "Bullet list", icon: "•–", prefix: "- " },
|
|
28
|
+
{ label: "Numbered list", icon: "1.", prefix: "1. " },
|
|
29
|
+
{ label: "Divider", icon: "—", block: `
|
|
30
|
+
---
|
|
31
|
+
|
|
32
|
+
` }
|
|
33
|
+
];
|
|
34
|
+
function X() {
|
|
35
|
+
return (/* @__PURE__ */ new Date()).toISOString().split("T")[0];
|
|
59
36
|
}
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
37
|
+
function B(t) {
|
|
38
|
+
return t.toLowerCase().replace(/[^a-z0-9\s-]/g, "").trim().replace(/\s+/g, "-").replace(/-+/g, "-");
|
|
39
|
+
}
|
|
40
|
+
function L(t) {
|
|
41
|
+
const e = t.trim().split(/\s+/).filter(Boolean).length;
|
|
42
|
+
return Math.max(1, Math.ceil(e / 200));
|
|
43
|
+
}
|
|
44
|
+
const c = s(((H = n.initialPost) == null ? void 0 : H.title) ?? ""), p = s(((R = n.initialPost) == null ? void 0 : R.slug) ?? ""), h = s(((M = n.initialPost) == null ? void 0 : M.date) ?? X()), g = s(((F = n.initialPost) == null ? void 0 : F.summary) ?? ""), k = s(((N = n.initialPost) == null ? void 0 : N.excerpt) ?? ""), o = s([...((O = n.initialPost) == null ? void 0 : O.tags) ?? []]), d = s((($ = n.initialPost) == null ? void 0 : $.readingTime) ?? 1), i = s(((q = n.initialPost) == null ? void 0 : q.content) ?? ""), y = s((A = n.initialPost) == null ? void 0 : A.coverImage), f = s(""), T = s(!!n.initialPost), V = s(null);
|
|
45
|
+
ie(() => n.initialPost, (t) => {
|
|
46
|
+
t && (c.value = t.title, p.value = t.slug, h.value = t.date, g.value = t.summary, k.value = t.excerpt ?? "", o.value = [...t.tags], d.value = t.readingTime ?? 1, i.value = t.content, y.value = t.coverImage, T.value = !0);
|
|
47
|
+
});
|
|
48
|
+
const Y = E(() => ue.parse(i.value)), D = E(() => c.value.trim().length > 0 && g.value.trim().length > 0 && i.value.trim().length > 0), S = E(() => y.value ?? n.coverImageUrl);
|
|
49
|
+
function Z(t) {
|
|
50
|
+
c.value = t.target.value, T.value || (p.value = B(c.value)), d.value = L(i.value);
|
|
51
|
+
}
|
|
52
|
+
function ee(t) {
|
|
53
|
+
i.value = t.target.value, d.value = L(i.value);
|
|
54
|
+
}
|
|
55
|
+
function le(t) {
|
|
56
|
+
if (t.key === "Enter" || t.key === ",") {
|
|
57
|
+
t.preventDefault();
|
|
58
|
+
const e = f.value.trim().replace(/,/g, "").toLowerCase();
|
|
59
|
+
e && !o.value.includes(e) && (o.value = [...o.value, e]), f.value = "";
|
|
60
|
+
}
|
|
61
|
+
t.key === "Backspace" && !f.value && o.value.length && (o.value = o.value.slice(0, -1));
|
|
62
|
+
}
|
|
63
|
+
function te(t) {
|
|
64
|
+
o.value = o.value.filter((e) => e !== t);
|
|
65
|
+
}
|
|
66
|
+
function ae(t) {
|
|
67
|
+
var r;
|
|
68
|
+
const e = (r = t.target.files) == null ? void 0 : r[0];
|
|
69
|
+
if (!e) return;
|
|
70
|
+
U("coverImageSelected", e);
|
|
71
|
+
const a = new FileReader();
|
|
72
|
+
a.onload = () => {
|
|
73
|
+
y.value = a.result;
|
|
74
|
+
}, a.readAsDataURL(e);
|
|
75
|
+
}
|
|
76
|
+
function ne(t) {
|
|
77
|
+
const e = V.value;
|
|
78
|
+
if (!e) return;
|
|
79
|
+
const a = e.selectionStart, r = e.selectionEnd, u = i.value;
|
|
80
|
+
let C, I;
|
|
81
|
+
if (t.wrap) {
|
|
82
|
+
const [m, K] = t.wrap, z = u.slice(a, r) || "text";
|
|
83
|
+
C = u.slice(0, a) + m + z + K + u.slice(r), I = a + m.length + z.length + K.length;
|
|
84
|
+
} else if (t.prefix) {
|
|
85
|
+
const m = u.lastIndexOf(`
|
|
86
|
+
`, a - 1) + 1;
|
|
87
|
+
C = u.slice(0, m) + t.prefix + u.slice(m), I = a + t.prefix.length;
|
|
88
|
+
} else if (t.block)
|
|
89
|
+
C = u.slice(0, a) + t.block + u.slice(r), I = a + t.block.length;
|
|
90
|
+
else
|
|
91
|
+
return;
|
|
92
|
+
i.value = C, setTimeout(() => {
|
|
93
|
+
e.selectionStart = e.selectionEnd = I, e.focus();
|
|
94
|
+
}, 0);
|
|
95
|
+
}
|
|
96
|
+
function se() {
|
|
97
|
+
D.value && U("publish", {
|
|
98
|
+
title: c.value,
|
|
99
|
+
slug: p.value || B(c.value),
|
|
100
|
+
date: h.value,
|
|
101
|
+
summary: g.value,
|
|
102
|
+
excerpt: k.value || void 0,
|
|
103
|
+
tags: o.value,
|
|
104
|
+
readingTime: d.value,
|
|
105
|
+
content: i.value,
|
|
106
|
+
coverImage: n.coverImageUrl ?? y.value
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
return (t, e) => (_(), w("div", ce, [
|
|
110
|
+
l("section", de, [
|
|
111
|
+
l("div", ve, [
|
|
112
|
+
e[7] || (e[7] = l("label", { class: "be-label" }, [
|
|
113
|
+
x("Title "),
|
|
114
|
+
l("span", { class: "be-required" }, "*")
|
|
115
|
+
], -1)),
|
|
116
|
+
l("input", {
|
|
117
|
+
class: "be-input",
|
|
118
|
+
type: "text",
|
|
119
|
+
value: c.value,
|
|
120
|
+
onInput: Z,
|
|
121
|
+
placeholder: "Post title…"
|
|
122
|
+
}, null, 40, be)
|
|
123
|
+
]),
|
|
124
|
+
l("div", pe, [
|
|
125
|
+
e[8] || (e[8] = l("label", { class: "be-label" }, "Slug", -1)),
|
|
126
|
+
v(l("input", {
|
|
127
|
+
class: "be-input",
|
|
128
|
+
type: "text",
|
|
129
|
+
"onUpdate:modelValue": e[0] || (e[0] = (a) => p.value = a),
|
|
130
|
+
onInput: e[1] || (e[1] = (a) => T.value = !0),
|
|
131
|
+
placeholder: "post-slug"
|
|
132
|
+
}, null, 544), [
|
|
133
|
+
[b, p.value]
|
|
134
|
+
])
|
|
135
|
+
]),
|
|
136
|
+
l("div", ge, [
|
|
137
|
+
e[9] || (e[9] = l("label", { class: "be-label" }, "Date", -1)),
|
|
138
|
+
v(l("input", {
|
|
139
|
+
class: "be-input",
|
|
140
|
+
type: "date",
|
|
141
|
+
"onUpdate:modelValue": e[2] || (e[2] = (a) => h.value = a)
|
|
142
|
+
}, null, 512), [
|
|
143
|
+
[b, h.value]
|
|
144
|
+
])
|
|
145
|
+
]),
|
|
146
|
+
l("div", fe, [
|
|
147
|
+
e[10] || (e[10] = l("label", { class: "be-label" }, [
|
|
148
|
+
x("Summary "),
|
|
149
|
+
l("span", { class: "be-required" }, "*")
|
|
150
|
+
], -1)),
|
|
151
|
+
v(l("textarea", {
|
|
152
|
+
class: "be-input be-input--textarea",
|
|
153
|
+
rows: "2",
|
|
154
|
+
"onUpdate:modelValue": e[3] || (e[3] = (a) => g.value = a),
|
|
155
|
+
placeholder: "Short description shown in blog listings…"
|
|
156
|
+
}, null, 512), [
|
|
157
|
+
[b, g.value]
|
|
158
|
+
])
|
|
159
|
+
]),
|
|
160
|
+
l("div", me, [
|
|
161
|
+
e[11] || (e[11] = l("label", { class: "be-label" }, [
|
|
162
|
+
x("Excerpt "),
|
|
163
|
+
l("span", { class: "be-optional" }, "(optional)")
|
|
164
|
+
], -1)),
|
|
165
|
+
v(l("textarea", {
|
|
166
|
+
class: "be-input be-input--textarea",
|
|
167
|
+
rows: "2",
|
|
168
|
+
"onUpdate:modelValue": e[4] || (e[4] = (a) => k.value = a),
|
|
169
|
+
placeholder: "Longer teaser for social previews…"
|
|
170
|
+
}, null, 512), [
|
|
171
|
+
[b, k.value]
|
|
172
|
+
])
|
|
173
|
+
]),
|
|
174
|
+
l("div", _e, [
|
|
175
|
+
e[12] || (e[12] = l("label", { class: "be-label" }, "Tags", -1)),
|
|
176
|
+
l("div", we, [
|
|
177
|
+
(_(!0), w(W, null, j(o.value, (a) => (_(), w("span", {
|
|
178
|
+
key: a,
|
|
179
|
+
class: "be-tag"
|
|
180
|
+
}, [
|
|
181
|
+
x(P(a) + " ", 1),
|
|
182
|
+
l("button", {
|
|
183
|
+
type: "button",
|
|
184
|
+
class: "be-tag__remove",
|
|
185
|
+
onClick: (r) => te(a),
|
|
186
|
+
"aria-label": `Remove tag ${a}`
|
|
187
|
+
}, "×", 8, xe)
|
|
188
|
+
]))), 128)),
|
|
189
|
+
v(l("input", {
|
|
190
|
+
class: "be-tag-input",
|
|
191
|
+
type: "text",
|
|
192
|
+
"onUpdate:modelValue": e[5] || (e[5] = (a) => f.value = a),
|
|
193
|
+
onKeydown: le,
|
|
194
|
+
placeholder: "Add tag, press Enter…"
|
|
195
|
+
}, null, 544), [
|
|
196
|
+
[b, f.value]
|
|
197
|
+
])
|
|
198
|
+
])
|
|
199
|
+
]),
|
|
200
|
+
l("div", he, [
|
|
201
|
+
e[13] || (e[13] = l("label", { class: "be-label" }, "Reading time (min)", -1)),
|
|
202
|
+
v(l("input", {
|
|
203
|
+
class: "be-input be-input--narrow",
|
|
204
|
+
type: "number",
|
|
205
|
+
min: "1",
|
|
206
|
+
"onUpdate:modelValue": e[6] || (e[6] = (a) => d.value = a)
|
|
207
|
+
}, null, 512), [
|
|
208
|
+
[
|
|
209
|
+
b,
|
|
210
|
+
d.value,
|
|
211
|
+
void 0,
|
|
212
|
+
{ number: !0 }
|
|
213
|
+
]
|
|
214
|
+
])
|
|
70
215
|
]),
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
216
|
+
l("div", ke, [
|
|
217
|
+
e[14] || (e[14] = l("label", { class: "be-label" }, "Cover Image", -1)),
|
|
218
|
+
l("div", ye, [
|
|
219
|
+
S.value ? (_(), w("img", {
|
|
220
|
+
key: 0,
|
|
221
|
+
class: "be-cover__preview",
|
|
222
|
+
src: S.value,
|
|
223
|
+
alt: "Cover preview"
|
|
224
|
+
}, null, 8, Ce)) : re("", !0),
|
|
225
|
+
l("label", Ie, [
|
|
226
|
+
x(P(S.value ? "Replace" : "Choose image") + " ", 1),
|
|
227
|
+
l("input", {
|
|
228
|
+
type: "file",
|
|
229
|
+
accept: "image/*",
|
|
230
|
+
onChange: ae,
|
|
231
|
+
hidden: ""
|
|
232
|
+
}, null, 32)
|
|
233
|
+
])
|
|
234
|
+
])
|
|
235
|
+
])
|
|
236
|
+
]),
|
|
237
|
+
l("section", Pe, [
|
|
238
|
+
l("div", Te, [
|
|
239
|
+
(_(), w(W, null, j(Q, (a) => l("button", {
|
|
240
|
+
key: a.label,
|
|
241
|
+
type: "button",
|
|
242
|
+
class: "be-toolbar__btn",
|
|
243
|
+
title: a.label,
|
|
244
|
+
onClick: (r) => ne(a)
|
|
245
|
+
}, P(a.icon), 9, Se)), 64))
|
|
79
246
|
]),
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
247
|
+
l("div", Ee, [
|
|
248
|
+
l("div", Ue, [
|
|
249
|
+
e[15] || (e[15] = l("div", { class: "be-pane__label" }, "Markdown", -1)),
|
|
250
|
+
l("textarea", {
|
|
251
|
+
ref_key: "textareaEl",
|
|
252
|
+
ref: V,
|
|
253
|
+
class: "be-pane__textarea",
|
|
254
|
+
value: i.value,
|
|
255
|
+
onInput: ee,
|
|
256
|
+
placeholder: "Write your post in markdown…",
|
|
257
|
+
spellcheck: "true"
|
|
258
|
+
}, null, 40, Be)
|
|
259
|
+
]),
|
|
260
|
+
l("div", Le, [
|
|
261
|
+
e[16] || (e[16] = l("div", { class: "be-pane__label" }, "Preview", -1)),
|
|
262
|
+
l("div", {
|
|
263
|
+
class: "be-pane__preview prose",
|
|
264
|
+
innerHTML: Y.value
|
|
265
|
+
}, null, 8, Ve)
|
|
266
|
+
])
|
|
267
|
+
])
|
|
268
|
+
]),
|
|
269
|
+
l("footer", De, [
|
|
270
|
+
l("span", He, "~" + P(d.value) + " min read", 1),
|
|
271
|
+
l("button", {
|
|
272
|
+
type: "button",
|
|
273
|
+
class: "be-publish",
|
|
274
|
+
disabled: !D.value,
|
|
275
|
+
onClick: se
|
|
276
|
+
}, " Publish Post ", 8, Re)
|
|
277
|
+
])
|
|
107
278
|
]));
|
|
108
279
|
}
|
|
109
280
|
});
|
|
110
281
|
export {
|
|
111
|
-
|
|
282
|
+
Ne as default
|
|
112
283
|
};
|
package/dist/index28.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const e=require("vue"),
|
|
1
|
+
"use strict";const e=require("vue"),h={class:"table-panel"},f={key:0,class:"dt-empty"},g={class:"dt-toolbar"},y=["placeholder","value"],C={class:"dt-pills"},v=["onClick"],B={class:"dt-count"},E={key:0,class:"dt-col-panel"},p=["checked","onChange"],V={class:"dt-scroll"},b=e.defineComponent({__name:"DataTable",props:{columnDefs:{default:()=>[]},colVisibility:{default:()=>({})},statuses:{default:()=>[]},statusFilter:{default:"all"},statusLabels:{default:()=>({})},searchValue:{default:""},searchPlaceholder:{default:"Search…"},totalCount:{default:0},filteredCount:{default:0},emptyMessage:{default:"No data yet."}},emits:["searchChange","statusChange","colToggle"],setup(t,{emit:u}){const i=t,c=u,o=e.ref(!1),s=e.ref(null);function d(a){return a==="all"?"All":i.statusLabels[a]??a}function r(a){var n;(n=s.value)!=null&&n.contains(a.target)||(o.value=!1,document.removeEventListener("click",r))}function m(){o.value=!o.value,o.value&&setTimeout(()=>document.addEventListener("click",r),0)}return(a,n)=>(e.openBlock(),e.createElementBlock("div",h,[t.totalCount===0?(e.openBlock(),e.createElementBlock("p",f,e.toDisplayString(t.emptyMessage),1)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createElementVNode("div",g,[t.statuses.length>0?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("input",{class:"dt-search",type:"search",placeholder:t.searchPlaceholder,value:t.searchValue,onInput:n[0]||(n[0]=l=>c("searchChange",l.target.value))},null,40,y),e.createElementVNode("div",C,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.statuses,l=>(e.openBlock(),e.createElementBlock("button",{key:l,class:e.normalizeClass(["dt-pill",{"dt-pill--active":t.statusFilter===l}]),onClick:k=>c("statusChange",l)},e.toDisplayString(d(l)),11,v))),128))]),e.createElementVNode("span",B,e.toDisplayString(t.filteredCount)+" of "+e.toDisplayString(t.totalCount),1)],64)):e.createCommentVNode("",!0),t.columnDefs.length>0?(e.openBlock(),e.createElementBlock("div",{key:1,ref_key:"colWrapRef",ref:s,class:"dt-col-wrap"},[e.createElementVNode("button",{class:"dt-col-btn",onClick:m},"⚙ Columns"),o.value?(e.openBlock(),e.createElementBlock("div",E,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.columnDefs,l=>(e.openBlock(),e.createElementBlock("label",{key:l.key,class:"dt-col-check"},[e.createElementVNode("input",{type:"checkbox",checked:t.colVisibility[l.key]??!0,onChange:k=>c("colToggle",l.key)},null,40,p),e.createTextVNode(" "+e.toDisplayString(l.label),1)]))),128))])):e.createCommentVNode("",!0)],512)):e.createCommentVNode("",!0)]),e.createElementVNode("div",V,[e.renderSlot(a.$slots,"default")])],64))]))}});module.exports=b;
|
package/dist/index28.mjs
CHANGED
|
@@ -1,74 +1,89 @@
|
|
|
1
|
-
import { defineComponent as
|
|
2
|
-
const E = {
|
|
3
|
-
class: "m2s2-dialog-content",
|
|
4
|
-
role: "dialog",
|
|
5
|
-
"aria-modal": !0,
|
|
6
|
-
"aria-labelledby": "dialog-title"
|
|
7
|
-
}, N = { class: "dialog-header" }, V = {
|
|
8
|
-
id: "dialog-title",
|
|
9
|
-
class: "dialog-title"
|
|
10
|
-
}, x = { class: "dialog-body" }, D = {
|
|
1
|
+
import { defineComponent as V, ref as m, openBlock as l, createElementBlock as a, toDisplayString as u, Fragment as d, createElementVNode as n, renderList as k, normalizeClass as p, createCommentVNode as r, createTextVNode as D, renderSlot as L } from "vue";
|
|
2
|
+
const T = { class: "table-panel" }, E = {
|
|
11
3
|
key: 0,
|
|
12
|
-
class: "
|
|
13
|
-
}, S = {
|
|
4
|
+
class: "dt-empty"
|
|
5
|
+
}, N = { class: "dt-toolbar" }, S = ["placeholder", "value"], x = { class: "dt-pills" }, F = ["onClick"], $ = { class: "dt-count" }, w = {
|
|
14
6
|
key: 0,
|
|
15
|
-
class: "
|
|
16
|
-
},
|
|
17
|
-
__name: "
|
|
7
|
+
class: "dt-col-panel"
|
|
8
|
+
}, B = ["checked", "onChange"], M = { class: "dt-scroll" }, R = /* @__PURE__ */ V({
|
|
9
|
+
__name: "DataTable",
|
|
18
10
|
props: {
|
|
19
|
-
|
|
20
|
-
|
|
11
|
+
columnDefs: { default: () => [] },
|
|
12
|
+
colVisibility: { default: () => ({}) },
|
|
13
|
+
statuses: { default: () => [] },
|
|
14
|
+
statusFilter: { default: "all" },
|
|
15
|
+
statusLabels: { default: () => ({}) },
|
|
16
|
+
searchValue: { default: "" },
|
|
17
|
+
searchPlaceholder: { default: "Search…" },
|
|
18
|
+
totalCount: { default: 0 },
|
|
19
|
+
filteredCount: { default: 0 },
|
|
20
|
+
emptyMessage: { default: "No data yet." }
|
|
21
21
|
},
|
|
22
|
-
emits: ["
|
|
23
|
-
setup(e, { emit:
|
|
24
|
-
const
|
|
25
|
-
function
|
|
26
|
-
|
|
22
|
+
emits: ["searchChange", "statusChange", "colToggle"],
|
|
23
|
+
setup(e, { emit: g }) {
|
|
24
|
+
const v = e, i = g, o = m(!1), h = m(null);
|
|
25
|
+
function C(s) {
|
|
26
|
+
return s === "all" ? "All" : v.statusLabels[s] ?? s;
|
|
27
27
|
}
|
|
28
|
-
function
|
|
29
|
-
c
|
|
28
|
+
function f(s) {
|
|
29
|
+
var c;
|
|
30
|
+
(c = h.value) != null && c.contains(s.target) || (o.value = !1, document.removeEventListener("click", f));
|
|
30
31
|
}
|
|
31
|
-
function
|
|
32
|
-
o.
|
|
32
|
+
function y() {
|
|
33
|
+
o.value = !o.value, o.value && setTimeout(() => document.addEventListener("click", f), 0);
|
|
33
34
|
}
|
|
34
|
-
return (
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
e.
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
35
|
+
return (s, c) => (l(), a("div", T, [
|
|
36
|
+
e.totalCount === 0 ? (l(), a("p", E, u(e.emptyMessage), 1)) : (l(), a(d, { key: 1 }, [
|
|
37
|
+
n("div", N, [
|
|
38
|
+
e.statuses.length > 0 ? (l(), a(d, { key: 0 }, [
|
|
39
|
+
n("input", {
|
|
40
|
+
class: "dt-search",
|
|
41
|
+
type: "search",
|
|
42
|
+
placeholder: e.searchPlaceholder,
|
|
43
|
+
value: e.searchValue,
|
|
44
|
+
onInput: c[0] || (c[0] = (t) => i("searchChange", t.target.value))
|
|
45
|
+
}, null, 40, S),
|
|
46
|
+
n("div", x, [
|
|
47
|
+
(l(!0), a(d, null, k(e.statuses, (t) => (l(), a("button", {
|
|
48
|
+
key: t,
|
|
49
|
+
class: p(["dt-pill", { "dt-pill--active": e.statusFilter === t }]),
|
|
50
|
+
onClick: (b) => i("statusChange", t)
|
|
51
|
+
}, u(C(t)), 11, F))), 128))
|
|
52
|
+
]),
|
|
53
|
+
n("span", $, u(e.filteredCount) + " of " + u(e.totalCount), 1)
|
|
54
|
+
], 64)) : r("", !0),
|
|
55
|
+
e.columnDefs.length > 0 ? (l(), a("div", {
|
|
56
|
+
key: 1,
|
|
57
|
+
ref_key: "colWrapRef",
|
|
58
|
+
ref: h,
|
|
59
|
+
class: "dt-col-wrap"
|
|
42
60
|
}, [
|
|
43
|
-
n("
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
onClick: (z) => g(l)
|
|
62
|
-
}, d(l.label), 11, T))), 128))
|
|
63
|
-
])) : s("", !0)
|
|
64
|
-
])
|
|
65
|
-
], 32)) : s("", !0)
|
|
61
|
+
n("button", {
|
|
62
|
+
class: "dt-col-btn",
|
|
63
|
+
onClick: y
|
|
64
|
+
}, "⚙ Columns"),
|
|
65
|
+
o.value ? (l(), a("div", w, [
|
|
66
|
+
(l(!0), a(d, null, k(e.columnDefs, (t) => (l(), a("label", {
|
|
67
|
+
key: t.key,
|
|
68
|
+
class: "dt-col-check"
|
|
69
|
+
}, [
|
|
70
|
+
n("input", {
|
|
71
|
+
type: "checkbox",
|
|
72
|
+
checked: e.colVisibility[t.key] ?? !0,
|
|
73
|
+
onChange: (b) => i("colToggle", t.key)
|
|
74
|
+
}, null, 40, B),
|
|
75
|
+
D(" " + u(t.label), 1)
|
|
76
|
+
]))), 128))
|
|
77
|
+
])) : r("", !0)
|
|
78
|
+
], 512)) : r("", !0)
|
|
66
79
|
]),
|
|
67
|
-
|
|
68
|
-
|
|
80
|
+
n("div", M, [
|
|
81
|
+
L(s.$slots, "default")
|
|
82
|
+
])
|
|
83
|
+
], 64))
|
|
69
84
|
]));
|
|
70
85
|
}
|
|
71
86
|
});
|
|
72
87
|
export {
|
|
73
|
-
|
|
88
|
+
R as default
|
|
74
89
|
};
|
package/dist/index30.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const e=require("vue"),
|
|
1
|
+
"use strict";const e=require("vue"),b={key:0,class:"sub-form"},d=["disabled"],m=["disabled"],v=["disabled"],p={key:0,class:"sub-feedback sub-feedback--error"},k={key:1,class:"sub-success"},g={key:1,class:"sub-auth"},f=["disabled"],y={key:0,class:"sub-feedback sub-feedback--success"},h=["disabled"],B={key:2,class:"sub-feedback sub-feedback--error"},_=e.defineComponent({__name:"SubscribeForm",props:{mode:{default:"anon"},subscribeAnon:{},subscribeAuth:{},unsubscribeAuth:{}},setup(c){const u=c,n=e.ref(""),l=e.ref(""),t=e.ref("idle"),o=e.ref(!1),r=e.computed(()=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(n.value.trim()));async function a(){if(t.value!=="submitting")if(u.mode==="auth")if(o.value){if(!u.unsubscribeAuth)return;t.value="submitting";try{await u.unsubscribeAuth(),o.value=!1,t.value="idle"}catch{t.value="error"}}else{if(!u.subscribeAuth)return;t.value="submitting";try{await u.subscribeAuth(),o.value=!0,t.value="done"}catch{t.value="error"}}else{if(!r.value||!u.subscribeAnon)return;t.value="submitting";try{await u.subscribeAnon(n.value.trim(),l.value.trim()),t.value="done"}catch{t.value="error"}}}return(E,s)=>c.mode==="anon"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.value!=="done"?(e.openBlock(),e.createElementBlock("div",b,[e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":s[0]||(s[0]=i=>l.value=i),class:"sub-input",type:"text",placeholder:"Your name (optional)",disabled:t.value==="submitting"},null,8,d),[[e.vModelText,l.value]]),e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":s[1]||(s[1]=i=>n.value=i),class:"sub-input",type:"email",placeholder:"your@email.com",disabled:t.value==="submitting"},null,8,m),[[e.vModelText,n.value]]),e.createElementVNode("button",{class:"sub-btn",disabled:!r.value||t.value==="submitting",onClick:a},e.toDisplayString(t.value==="submitting"?"Submitting…":"Subscribe"),9,v),t.value==="error"?(e.openBlock(),e.createElementBlock("p",p," Something went wrong — please try again. ")):e.createCommentVNode("",!0)])):(e.openBlock(),e.createElementBlock("div",k,[...s[2]||(s[2]=[e.createElementVNode("span",{class:"sub-success-icon"},"✓",-1),e.createElementVNode("p",{class:"sub-success-text"},"Check your email to confirm your subscription.",-1)])]))],64)):(e.openBlock(),e.createElementBlock("div",g,[o.value?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[s[3]||(s[3]=e.createElementVNode("span",{class:"sub-subscribed-label"},"✓ Subscribed to blog updates",-1)),e.createElementVNode("button",{class:"sub-btn sub-btn--unsub",disabled:t.value==="submitting",onClick:a},e.toDisplayString(t.value==="submitting"?"Unsubscribing…":"Unsubscribe"),9,h)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("button",{class:"sub-btn",disabled:t.value==="submitting",onClick:a},e.toDisplayString(t.value==="submitting"?"Subscribing…":"Subscribe to Blog Updates"),9,f),t.value==="done"?(e.openBlock(),e.createElementBlock("p",y,"You're subscribed!")):e.createCommentVNode("",!0)],64)),t.value==="error"?(e.openBlock(),e.createElementBlock("p",B," Something went wrong — please try again. ")):e.createCommentVNode("",!0)]))}});module.exports=_;
|