@m2s2/vue-lib 2.1.0 → 2.3.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 (70) hide show
  1. package/dist/index.cjs +1 -1
  2. package/dist/index.mjs +28 -22
  3. package/dist/index16.cjs +1 -1
  4. package/dist/index16.mjs +1 -1
  5. package/dist/index26.cjs +6 -1
  6. package/dist/index26.mjs +271 -77
  7. package/dist/index28.cjs +1 -1
  8. package/dist/index28.mjs +78 -101
  9. package/dist/index30.cjs +1 -1
  10. package/dist/index30.mjs +101 -63
  11. package/dist/index32.cjs +1 -1
  12. package/dist/index32.mjs +52 -65
  13. package/dist/index34.cjs +1 -1
  14. package/dist/index34.mjs +85 -3
  15. package/dist/index36.cjs +1 -1
  16. package/dist/index36.mjs +26 -3
  17. package/dist/index38.cjs +1 -1
  18. package/dist/index38.mjs +2 -2
  19. package/dist/index39.cjs +1 -1
  20. package/dist/index39.mjs +2 -2
  21. package/dist/index40.cjs +1 -1
  22. package/dist/index40.mjs +2 -2
  23. package/dist/index41.cjs +1 -1
  24. package/dist/index41.mjs +2 -2
  25. package/dist/index42.cjs +1 -1
  26. package/dist/index42.mjs +1 -1
  27. package/dist/index43.cjs +1 -1
  28. package/dist/index43.mjs +1 -1
  29. package/dist/index44.cjs +1 -1
  30. package/dist/index44.mjs +1 -1
  31. package/dist/index45.cjs +1 -1
  32. package/dist/index45.mjs +1 -1
  33. package/dist/index46.cjs +1 -1
  34. package/dist/index46.mjs +1 -1
  35. package/dist/index47.cjs +1 -1
  36. package/dist/index47.mjs +1 -1
  37. package/dist/index48.cjs +1 -1
  38. package/dist/index48.mjs +1 -1
  39. package/dist/index49.cjs +1 -1
  40. package/dist/index49.mjs +1 -1
  41. package/dist/index50.cjs +1 -1
  42. package/dist/index50.mjs +3 -51
  43. package/dist/index51.cjs +1 -1
  44. package/dist/index51.mjs +3 -2
  45. package/dist/index52.cjs +1 -0
  46. package/dist/index52.mjs +5 -0
  47. package/dist/index53.cjs +1 -0
  48. package/dist/index53.mjs +5 -0
  49. package/dist/index54.cjs +1 -0
  50. package/dist/index54.mjs +5 -0
  51. package/dist/index55.cjs +1 -0
  52. package/dist/index55.mjs +5 -0
  53. package/dist/index56.cjs +59 -0
  54. package/dist/index56.mjs +1152 -0
  55. package/dist/index57.cjs +1 -0
  56. package/dist/index57.mjs +53 -0
  57. package/dist/index58.cjs +1 -0
  58. package/dist/index58.mjs +4 -0
  59. package/dist/vue-lib/src/components/BlogEditor/BlogEditor.vue.d.ts +16 -0
  60. package/dist/vue-lib/src/components/BlogEditor/BlogEditor.vue.d.ts.map +1 -0
  61. package/dist/vue-lib/src/components/LoadingButton/LoadingButton.vue.d.ts +19 -0
  62. package/dist/vue-lib/src/components/LoadingButton/LoadingButton.vue.d.ts.map +1 -0
  63. package/dist/vue-lib/src/index.d.ts +2 -0
  64. package/dist/vue-lib/src/index.d.ts.map +1 -1
  65. package/dist/vue-lib.css +1 -1
  66. package/package.json +8 -5
  67. package/dist/index35.cjs +0 -1
  68. package/dist/index35.mjs +0 -5
  69. package/dist/index37.cjs +0 -1
  70. package/dist/index37.mjs +0 -5
package/dist/index28.mjs CHANGED
@@ -1,112 +1,89 @@
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 _ = {
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 = {
3
3
  key: 0,
4
- class: "sub-form"
5
- }, A = ["disabled"], S = ["disabled"], w = ["disabled"], C = {
4
+ class: "dt-empty"
5
+ }, N = { class: "dt-toolbar" }, S = ["placeholder", "value"], x = { class: "dt-pills" }, F = ["onClick"], $ = { class: "dt-count" }, w = {
6
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",
7
+ class: "dt-col-panel"
8
+ }, B = ["checked", "onChange"], M = { class: "dt-scroll" }, R = /* @__PURE__ */ V({
9
+ __name: "DataTable",
22
10
  props: {
23
- mode: { default: "anon" },
24
- subscribeAnon: {},
25
- subscribeAuth: {},
26
- unsubscribeAuth: {}
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." }
27
21
  },
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
- }
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;
59
27
  }
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]
70
- ]),
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]
28
+ function f(s) {
29
+ var c;
30
+ (c = h.value) != null && c.contains(s.target) || (o.value = !1, document.removeEventListener("click", f));
31
+ }
32
+ function y() {
33
+ o.value = !o.value, o.value && setTimeout(() => document.addEventListener("click", f), 0);
34
+ }
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"
60
+ }, [
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)
79
79
  ]),
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)
80
+ n("div", M, [
81
+ L(s.$slots, "default")
82
+ ])
83
+ ], 64))
107
84
  ]));
108
85
  }
109
86
  });
110
87
  export {
111
- Y as default
88
+ R as default
112
89
  };
package/dist/index30.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"),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=_;
package/dist/index30.mjs CHANGED
@@ -1,74 +1,112 @@
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 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 _ = {
11
3
  key: 0,
12
- class: "dialog-message"
13
- }, S = {
4
+ class: "sub-form"
5
+ }, A = ["disabled"], S = ["disabled"], w = ["disabled"], C = {
14
6
  key: 0,
15
- class: "dialog-footer"
16
- }, T = ["onClick"], F = /* @__PURE__ */ k({
17
- __name: "Dialog",
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",
18
22
  props: {
19
- data: {},
20
- open: { type: Boolean }
23
+ mode: { default: "anon" },
24
+ subscribeAnon: {},
25
+ subscribeAuth: {},
26
+ unsubscribeAuth: {}
21
27
  },
22
- emits: ["action", "close"],
23
- setup(e, { emit: m }) {
24
- const c = e, i = m;
25
- function g(o) {
26
- i("action", o.value);
27
- }
28
- function u() {
29
- c.data.modal || i("close");
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
+ }
30
59
  }
31
- function f(o) {
32
- o.key === "Escape" && !c.data.modal && i("close");
33
- }
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
42
- }, [
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)
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]
70
+ ]),
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]
66
79
  ]),
67
- _: 3
68
- })
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)
69
107
  ]));
70
108
  }
71
109
  });
72
110
  export {
73
- F as default
111
+ Y as default
74
112
  };
package/dist/index32.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"),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;
package/dist/index32.mjs CHANGED
@@ -1,87 +1,74 @@
1
- import { defineComponent as C, openBlock as t, createBlock as g, Teleport as $, createVNode as h, Transition as y, withCtx as k, createElementBlock as a, withModifiers as w, createCommentVNode as l, normalizeStyle as B, normalizeClass as f, createElementVNode as o, toDisplayString as i, renderSlot as N, Fragment as S, renderList as V } from "vue";
2
- const x = { class: "panel-header" }, z = { class: "panel-header-text" }, E = {
3
- id: "panel-title",
4
- class: "panel-title"
5
- }, T = {
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 = {
6
11
  key: 0,
7
- class: "panel-subtitle"
8
- }, A = { class: "panel-body" }, D = {
12
+ class: "dialog-message"
13
+ }, S = {
9
14
  key: 0,
10
- class: "panel-message"
11
- }, F = {
12
- key: 0,
13
- class: "panel-footer"
14
- }, L = ["onClick"], j = /* @__PURE__ */ C({
15
- __name: "Panel",
15
+ class: "dialog-footer"
16
+ }, T = ["onClick"], F = /* @__PURE__ */ k({
17
+ __name: "Dialog",
16
18
  props: {
17
19
  data: {},
18
20
  open: { type: Boolean }
19
21
  },
20
22
  emits: ["action", "close"],
21
- setup(e, { emit: b }) {
22
- const c = e, d = b, r = () => c.data.side ?? "right";
23
- function p(s) {
24
- d("action", s.value);
23
+ setup(e, { emit: m }) {
24
+ const c = e, i = m;
25
+ function g(o) {
26
+ i("action", o.value);
27
+ }
28
+ function u() {
29
+ c.data.modal || i("close");
25
30
  }
26
- function v() {
27
- c.data.modal || d("close");
31
+ function f(o) {
32
+ o.key === "Escape" && !c.data.modal && i("close");
28
33
  }
29
- return (s, m) => (t(), g($, { to: "body" }, [
30
- h(y, { name: "panel-overlay-fade" }, {
31
- default: k(() => [
34
+ return (o, r) => (t(), y(b, { to: "body" }, [
35
+ h(v, { name: "dialog-fade" }, {
36
+ default: C(() => [
32
37
  e.open ? (t(), a("div", {
33
38
  key: 0,
34
- class: "m2s2-panel-overlay",
35
- onClick: w(v, ["self"])
36
- })) : l("", !0)
37
- ]),
38
- _: 1
39
- }),
40
- h(y, {
41
- name: `panel-slide-${r()}`
42
- }, {
43
- default: k(() => {
44
- var u;
45
- return [
46
- e.open ? (t(), a("div", {
47
- key: 0,
48
- class: f(["m2s2-panel-content", `m2s2-panel-content--${r()}`]),
49
- style: B(e.data.width ? { "--panel-width": e.data.width } : {}),
50
- role: "dialog",
51
- "aria-modal": !0,
52
- "aria-labelledby": "panel-title"
53
- }, [
54
- o("div", x, [
55
- o("div", z, [
56
- o("h2", E, i(e.data.title), 1),
57
- e.data.subtitle ? (t(), a("p", T, i(e.data.subtitle), 1)) : l("", !0)
58
- ]),
59
- e.data.modal ? l("", !0) : (t(), a("button", {
39
+ class: "m2s2-dialog-overlay",
40
+ onClick: B(u, ["self"]),
41
+ onKeydown: f
42
+ }, [
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", {
60
47
  key: 0,
61
- class: "panel-close",
48
+ class: "dialog-close",
62
49
  "aria-label": "Close",
63
- onClick: m[0] || (m[0] = (n) => d("close"))
50
+ onClick: r[0] || (r[0] = (l) => i("close"))
64
51
  }, "✕"))
65
52
  ]),
66
- o("div", A, [
67
- e.data.message && !s.$slots.default ? (t(), a("p", D, i(e.data.message), 1)) : l("", !0),
68
- N(s.$slots, "default")
53
+ n("div", x, [
54
+ e.data.message ? (t(), a("p", D, d(e.data.message), 1)) : s("", !0),
55
+ _(o.$slots, "default")
69
56
  ]),
70
- (u = e.data.actions) != null && u.length ? (t(), a("div", F, [
71
- (t(!0), a(S, null, V(e.data.actions, (n) => (t(), a("button", {
72
- key: n.label,
73
- class: f(["panel-btn", `panel-btn--${n.variant ?? "secondary"}`]),
74
- onClick: (M) => p(n)
75
- }, i(n.label), 11, L))), 128))
76
- ])) : l("", !0)
77
- ], 6)) : l("", !0)
78
- ];
79
- }),
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)
66
+ ]),
80
67
  _: 3
81
- }, 8, ["name"])
68
+ })
82
69
  ]));
83
70
  }
84
71
  });
85
72
  export {
86
- j as default
73
+ F as default
87
74
  };
package/dist/index34.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";const e=require("./index2.cjs");;/* empty css */module.exports=e;
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;