@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.
Files changed (88) hide show
  1. package/dist/index.cjs +1 -1
  2. package/dist/index.mjs +34 -28
  3. package/dist/index10.cjs +1 -1
  4. package/dist/index10.mjs +8 -16
  5. package/dist/index12.cjs +1 -1
  6. package/dist/index12.mjs +15 -19
  7. package/dist/index14.cjs +1 -1
  8. package/dist/index14.mjs +20 -27
  9. package/dist/index16.cjs +1 -1
  10. package/dist/index16.mjs +28 -262
  11. package/dist/index18.cjs +1 -1
  12. package/dist/index18.mjs +263 -13
  13. package/dist/index2.cjs +1 -1
  14. package/dist/index2.mjs +250 -11
  15. package/dist/index20.cjs +1 -1
  16. package/dist/index20.mjs +13 -38
  17. package/dist/index22.cjs +1 -1
  18. package/dist/index22.mjs +35 -49
  19. package/dist/index24.cjs +1 -1
  20. package/dist/index24.mjs +47 -78
  21. package/dist/index26.cjs +6 -1
  22. package/dist/index26.mjs +273 -102
  23. package/dist/index28.cjs +1 -1
  24. package/dist/index28.mjs +75 -60
  25. package/dist/index30.cjs +1 -1
  26. package/dist/index30.mjs +100 -75
  27. package/dist/index32.cjs +1 -1
  28. package/dist/index32.mjs +72 -3
  29. package/dist/index34.cjs +1 -1
  30. package/dist/index34.mjs +85 -3
  31. package/dist/index36.cjs +1 -1
  32. package/dist/index36.mjs +2 -2
  33. package/dist/index37.cjs +1 -1
  34. package/dist/index37.mjs +2 -2
  35. package/dist/index38.cjs +1 -1
  36. package/dist/index38.mjs +2 -2
  37. package/dist/index39.cjs +1 -1
  38. package/dist/index39.mjs +2 -2
  39. package/dist/index4.cjs +1 -1
  40. package/dist/index4.mjs +11 -19
  41. package/dist/index40.cjs +1 -1
  42. package/dist/index40.mjs +1 -1
  43. package/dist/index41.cjs +1 -1
  44. package/dist/index41.mjs +1 -1
  45. package/dist/index42.cjs +1 -1
  46. package/dist/index42.mjs +1 -1
  47. package/dist/index43.cjs +1 -1
  48. package/dist/index43.mjs +1 -1
  49. package/dist/index44.cjs +1 -1
  50. package/dist/index44.mjs +1 -1
  51. package/dist/index45.cjs +1 -1
  52. package/dist/index45.mjs +1 -1
  53. package/dist/index46.cjs +1 -1
  54. package/dist/index46.mjs +1 -1
  55. package/dist/index47.cjs +1 -1
  56. package/dist/index47.mjs +3 -51
  57. package/dist/index48.cjs +1 -1
  58. package/dist/index48.mjs +3 -2
  59. package/dist/index49.cjs +1 -0
  60. package/dist/index49.mjs +5 -0
  61. package/dist/index50.cjs +1 -0
  62. package/dist/index50.mjs +5 -0
  63. package/dist/index51.cjs +1 -0
  64. package/dist/index51.mjs +5 -0
  65. package/dist/index52.cjs +1 -0
  66. package/dist/index52.mjs +5 -0
  67. package/dist/index53.cjs +59 -0
  68. package/dist/index53.mjs +1152 -0
  69. package/dist/index54.cjs +1 -0
  70. package/dist/index54.mjs +53 -0
  71. package/dist/index55.cjs +1 -0
  72. package/dist/index55.mjs +4 -0
  73. package/dist/index6.cjs +1 -1
  74. package/dist/index6.mjs +21 -15
  75. package/dist/index8.cjs +1 -1
  76. package/dist/index8.mjs +15 -10
  77. package/dist/vue-lib/src/components/BlogEditor/BlogEditor.vue.d.ts +16 -0
  78. package/dist/vue-lib/src/components/BlogEditor/BlogEditor.vue.d.ts.map +1 -0
  79. package/dist/vue-lib/src/components/Chat/Chat.vue.d.ts +22 -0
  80. package/dist/vue-lib/src/components/Chat/Chat.vue.d.ts.map +1 -0
  81. package/dist/vue-lib/src/index.d.ts +2 -0
  82. package/dist/vue-lib/src/index.d.ts.map +1 -1
  83. package/dist/vue-lib.css +1 -1
  84. package/package.json +8 -5
  85. package/dist/index33.cjs +0 -1
  86. package/dist/index33.mjs +0 -5
  87. package/dist/index35.cjs +0 -1
  88. package/dist/index35.mjs +0 -5
package/dist/index26.mjs CHANGED
@@ -1,112 +1,283 @@
1
- import { defineComponent as k, ref as o, computed as y, openBlock as s, createElementBlock as t, Fragment as d, withDirectives as f, createElementVNode as i, vModelText as h, toDisplayString as m, createCommentVNode as v } from "vue";
2
- const _ = {
3
- key: 0,
4
- class: "sub-form"
5
- }, A = ["disabled"], S = ["disabled"], w = ["disabled"], C = {
6
- key: 0,
7
- class: "sub-feedback sub-feedback--error"
8
- }, x = {
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
- mode: { default: "anon" },
24
- subscribeAnon: {},
25
- subscribeAuth: {},
26
- unsubscribeAuth: {}
10
+ initialPost: {},
11
+ coverImageUrl: {}
27
12
  },
28
- setup(p) {
29
- const a = p, n = o(""), b = o(""), e = o("idle"), l = o(!1), g = y(() => /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(n.value.trim()));
30
- async function r() {
31
- if (e.value !== "submitting")
32
- if (a.mode === "auth")
33
- if (l.value) {
34
- if (!a.unsubscribeAuth) return;
35
- e.value = "submitting";
36
- try {
37
- await a.unsubscribeAuth(), l.value = !1, e.value = "idle";
38
- } catch {
39
- e.value = "error";
40
- }
41
- } else {
42
- if (!a.subscribeAuth) return;
43
- e.value = "submitting";
44
- try {
45
- await a.subscribeAuth(), l.value = !0, e.value = "done";
46
- } catch {
47
- e.value = "error";
48
- }
49
- }
50
- else {
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: `![alt text](image-url)
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
- return (F, u) => p.mode === "anon" ? (s(), t(d, { key: 0 }, [
61
- e.value !== "done" ? (s(), t("div", _, [
62
- f(i("input", {
63
- "onUpdate:modelValue": u[0] || (u[0] = (c) => b.value = c),
64
- class: "sub-input",
65
- type: "text",
66
- placeholder: "Your name (optional)",
67
- disabled: e.value === "submitting"
68
- }, null, 8, A), [
69
- [h, b.value]
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
- f(i("input", {
72
- "onUpdate:modelValue": u[1] || (u[1] = (c) => n.value = c),
73
- class: "sub-input",
74
- type: "email",
75
- placeholder: "your@email.com",
76
- disabled: e.value === "submitting"
77
- }, null, 8, S), [
78
- [h, n.value]
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
- i("button", {
81
- class: "sub-btn",
82
- disabled: !g.value || e.value === "submitting",
83
- onClick: r
84
- }, m(e.value === "submitting" ? "Submitting…" : "Subscribe"), 9, w),
85
- e.value === "error" ? (s(), t("p", C, " Something went wrong — please try again. ")) : v("", !0)
86
- ])) : (s(), t("div", x, [...u[2] || (u[2] = [
87
- i("span", { class: "sub-success-icon" }, "✓", -1),
88
- i("p", { class: "sub-success-text" }, "Check your email to confirm your subscription.", -1)
89
- ])]))
90
- ], 64)) : (s(), t("div", U, [
91
- l.value ? (s(), t(d, { key: 1 }, [
92
- u[3] || (u[3] = i("span", { class: "sub-subscribed-label" }, "✓ Subscribed to blog updates", -1)),
93
- i("button", {
94
- class: "sub-btn sub-btn--unsub",
95
- disabled: e.value === "submitting",
96
- onClick: r
97
- }, m(e.value === "submitting" ? "Unsubscribing…" : "Unsubscribe"), 9, D)
98
- ], 64)) : (s(), t(d, { key: 0 }, [
99
- i("button", {
100
- class: "sub-btn",
101
- disabled: e.value === "submitting",
102
- onClick: r
103
- }, m(e.value === "submitting" ? "Subscribing…" : "Subscribe to Blog Updates"), 9, V),
104
- e.value === "done" ? (s(), t("p", B, "You're subscribed!")) : v("", !0)
105
- ], 64)),
106
- e.value === "error" ? (s(), t("p", E, " Something went wrong — please try again. ")) : v("", !0)
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
- Y as default
282
+ Ne as default
112
283
  };
package/dist/index28.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";const e=require("vue"),m={class:"m2s2-dialog-content",role:"dialog","aria-modal":!0,"aria-labelledby":"dialog-title"},k={class:"dialog-header"},g={id:"dialog-title",class:"dialog-title"},u={class:"dialog-body"},y={key:0,class:"dialog-message"},B={key:0,class:"dialog-footer"},f=["onClick"],C=e.defineComponent({__name:"Dialog",props:{data:{},open:{type:Boolean}},emits:["action","close"],setup(t,{emit:i}){const n=t,l=i;function s(o){l("action",o.value)}function d(){n.data.modal||l("close")}function r(o){o.key==="Escape"&&!n.data.modal&&l("close")}return(o,c)=>(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[e.createVNode(e.Transition,{name:"dialog-fade"},{default:e.withCtx(()=>[t.open?(e.openBlock(),e.createElementBlock("div",{key:0,class:"m2s2-dialog-overlay",onClick:e.withModifiers(d,["self"]),onKeydown:r},[e.createElementVNode("div",m,[e.createElementVNode("div",k,[e.createElementVNode("h2",g,e.toDisplayString(t.data.title),1),t.data.modal?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,class:"dialog-close","aria-label":"Close",onClick:c[0]||(c[0]=a=>l("close"))},"✕"))]),e.createElementVNode("div",u,[t.data.message?(e.openBlock(),e.createElementBlock("p",y,e.toDisplayString(t.data.message),1)):e.createCommentVNode("",!0),e.renderSlot(o.$slots,"default")]),t.data.actions.length?(e.openBlock(),e.createElementBlock("div",B,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.data.actions,a=>(e.openBlock(),e.createElementBlock("button",{key:a.label,class:e.normalizeClass(["dialog-btn",`dialog-btn--${a.variant??"secondary"}`]),onClick:b=>s(a)},e.toDisplayString(a.label),11,f))),128))])):e.createCommentVNode("",!0)])],32)):e.createCommentVNode("",!0)]),_:3})]))}});module.exports=C;
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 k, openBlock as t, createBlock as y, Teleport as b, createVNode as h, Transition as v, withCtx as C, createElementBlock as a, withModifiers as B, createElementVNode as n, toDisplayString as d, createCommentVNode as s, renderSlot as _, Fragment as $, renderList as p, normalizeClass as w } from "vue";
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: "dialog-message"
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: "dialog-footer"
16
- }, T = ["onClick"], F = /* @__PURE__ */ k({
17
- __name: "Dialog",
7
+ class: "dt-col-panel"
8
+ }, B = ["checked", "onChange"], M = { class: "dt-scroll" }, R = /* @__PURE__ */ V({
9
+ __name: "DataTable",
18
10
  props: {
19
- data: {},
20
- open: { type: Boolean }
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: ["action", "close"],
23
- setup(e, { emit: m }) {
24
- const c = e, i = m;
25
- function g(o) {
26
- i("action", o.value);
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 u() {
29
- c.data.modal || i("close");
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 f(o) {
32
- o.key === "Escape" && !c.data.modal && i("close");
32
+ function y() {
33
+ o.value = !o.value, o.value && setTimeout(() => document.addEventListener("click", f), 0);
33
34
  }
34
- return (o, r) => (t(), y(b, { to: "body" }, [
35
- h(v, { name: "dialog-fade" }, {
36
- default: C(() => [
37
- e.open ? (t(), a("div", {
38
- key: 0,
39
- class: "m2s2-dialog-overlay",
40
- onClick: B(u, ["self"]),
41
- onKeydown: f
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("div", E, [
44
- n("div", N, [
45
- n("h2", V, d(e.data.title), 1),
46
- e.data.modal ? s("", !0) : (t(), a("button", {
47
- key: 0,
48
- class: "dialog-close",
49
- "aria-label": "Close",
50
- onClick: r[0] || (r[0] = (l) => i("close"))
51
- }, "✕"))
52
- ]),
53
- n("div", x, [
54
- e.data.message ? (t(), a("p", D, d(e.data.message), 1)) : s("", !0),
55
- _(o.$slots, "default")
56
- ]),
57
- e.data.actions.length ? (t(), a("div", S, [
58
- (t(!0), a($, null, p(e.data.actions, (l) => (t(), a("button", {
59
- key: l.label,
60
- class: w(["dialog-btn", `dialog-btn--${l.variant ?? "secondary"}`]),
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
- _: 3
68
- })
80
+ n("div", M, [
81
+ L(s.$slots, "default")
82
+ ])
83
+ ], 64))
69
84
  ]));
70
85
  }
71
86
  });
72
87
  export {
73
- F as default
88
+ R as default
74
89
  };
package/dist/index30.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";const e=require("vue"),k={class:"panel-header"},u={class:"panel-header-text"},p={id:"panel-title",class:"panel-title"},y={key:0,class:"panel-subtitle"},B={class:"panel-body"},h={key:0,class:"panel-message"},C={key:0,class:"panel-footer"},b=["onClick"],f=e.defineComponent({__name:"Panel",props:{data:{},open:{type:Boolean}},emits:["action","close"],setup(t,{emit:d}){const o=t,n=d,s=()=>o.data.side??"right";function r(l){n("action",l.value)}function m(){o.data.modal||n("close")}return(l,c)=>(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[e.createVNode(e.Transition,{name:"panel-overlay-fade"},{default:e.withCtx(()=>[t.open?(e.openBlock(),e.createElementBlock("div",{key:0,class:"m2s2-panel-overlay",onClick:e.withModifiers(m,["self"])})):e.createCommentVNode("",!0)]),_:1}),e.createVNode(e.Transition,{name:`panel-slide-${s()}`},{default:e.withCtx(()=>{var i;return[t.open?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["m2s2-panel-content",`m2s2-panel-content--${s()}`]),style:e.normalizeStyle(t.data.width?{"--panel-width":t.data.width}:{}),role:"dialog","aria-modal":!0,"aria-labelledby":"panel-title"},[e.createElementVNode("div",k,[e.createElementVNode("div",u,[e.createElementVNode("h2",p,e.toDisplayString(t.data.title),1),t.data.subtitle?(e.openBlock(),e.createElementBlock("p",y,e.toDisplayString(t.data.subtitle),1)):e.createCommentVNode("",!0)]),t.data.modal?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,class:"panel-close","aria-label":"Close",onClick:c[0]||(c[0]=a=>n("close"))},""))]),e.createElementVNode("div",B,[t.data.message&&!l.$slots.default?(e.openBlock(),e.createElementBlock("p",h,e.toDisplayString(t.data.message),1)):e.createCommentVNode("",!0),e.renderSlot(l.$slots,"default")]),(i=t.data.actions)!=null&&i.length?(e.openBlock(),e.createElementBlock("div",C,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.data.actions,a=>(e.openBlock(),e.createElementBlock("button",{key:a.label,class:e.normalizeClass(["panel-btn",`panel-btn--${a.variant??"secondary"}`]),onClick:v=>r(a)},e.toDisplayString(a.label),11,b))),128))])):e.createCommentVNode("",!0)],6)):e.createCommentVNode("",!0)]}),_:3},8,["name"])]))}});module.exports=f;
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=_;